1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
AppDelegate.m #import "AppDelegate.h" #import "MainViewController.h" @implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
// Override point for customization after application launch.
self.window.backgroundColor = [UIColor whiteColor];
[self.window makeKeyAndVisible];
MainViewController *mainVC = [[MainViewController alloc] init];
UINavigationController *naviVC = [[UINavigationController alloc] initWithRootViewController:mainVC];
self.window.rootViewController = naviVC;
[naviVC release];
[mainVC release];
[_window release];
return YES;
} - (void)dealloc { [_window release];
[ super dealloc];
} - (void)applicationWillResignActive:(UIApplication *)application { // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
// Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
} - (void)applicationDidEnterBackground:(UIApplication *)application { // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
} - (void)applicationWillEnterForeground:(UIApplication *)application { // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.
} - (void)applicationDidBecomeActive:(UIApplication *)application { // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
} - (void)applicationWillTerminate:(UIApplication *)application { // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
} @end |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
MainViewController.m #import "MainViewController.h" #import "XMLSAXParser.h" #import "JSONParser.h" @interface MainViewController () @end @implementation MainViewController - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil { self = [ super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
// Custom initialization
}
return self;
} - (void)viewDidLoad { [ super viewDidLoad];
// Do any additional setup after loading the view.
self.view.backgroundColor = [UIColor cyanColor];
//XML SAX解析(逐行解析)
XMLSAXParser *parser = [[XMLSAXParser alloc] init];
[parser startParse];
NSLog(@ "解析后的%@" ,parser.array);
[parser release];
} - (void)didReceiveMemoryWarning { [ super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
} /* #pragma mark - Navigation // In a storyboard-based application, you will often want to do a little preparation before navigation - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender { // Get the new view controller using [segue destinationViewController].
// Pass the selected object to the new view controller.
} */ @end |
1
2
3
4
5
6
7
8
|
XMLSAXParser.h #import <Foundation/Foundation.h> @interface XMLSAXParser : NSObject<NSXMLParserDelegate> @property (nonatomic , retain)NSMutableArray *array; //装学生对象
@property (nonatomic , retain)NSString *tempStr; //临时健在节点内容
- (void)startParse; //开始解析,逐行解析
- (void)startDOMParse; //开始dom解析,按节点解析
@end |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
XMLSAXParser.m #import "XMLSAXParser.h" #import "Student.h" #import "GDataXMLNode.h" @implementation XMLSAXParser //XML解析:逐行解析 - (void)startParse; { //XML解析:逐行解析
//从文件列表中读取数据
//1.获取文件路径
NSString *sourcePath = [[NSBundle mainBundle] pathForResource:@ "Student" ofType:@ "xml" ];
//2.通过路径把文件转换成NSData类型
NSData *data = [NSData dataWithContentsOfFile:sourcePath];
//创建的时候需要给parser一个字符串数据(NSData)
NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data];
//设定代理人
parser.delegate = self;
//开始对文件进行解析
[parser parse];
//内存管理
[parser release];
} - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict { //当找到节点头的时候,体统调用这个方法
NSLog(@ "节点头" );
if ([elementName isEqualToString:@ "students" ]) {
//当找到students节点头的时候,初始化数组
self.array = [NSMutableArray array];
} else if ([elementName isEqualToString:@ "student" ]){
//当找到student节点时候,创建一个新的学生对象,添加到数组中
Student *stu = [[Student alloc] init];
[self.array addObject:stu];
[stu release];
}
} - (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string { //当找到节点内容的时候,调用
NSLog(@ "节点内容" );
//把内容保存起来,只要碰到节点内容,下一个肯定是节点尾
self.tempStr = string;
} - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName { //当找到节点尾时候调用
NSLog(@ "节点尾" );
//取得之前保存的student对象
Student *stu = [self.array lastObject]; //核心代码,懂了没 .........
if ([elementName isEqualToString:@ "name" ]) {
stu.name = self.tempStr;
} else if ([elementName isEqualToString:@ "sex" ]){
stu.sex = self.tempStr;
} else if ([elementName isEqualToString:@ "phone" ]){
stu.phone = self.tempStr;
} else if ([elementName isEqualToString:@ "number" ]){
stu.number = self.tempStr;
}
} //开始dom解析,按节点解析 - (void)startDOMParse { //按节点解析
//1.获取要解析文件的文件信息
NSString *xmlPath = [[NSBundle mainBundle]pathForResource:@ "Student" ofType:@ "xml" ];
NSData *data = [NSData dataWithContentsOfFile:xmlPath];
//参数1:要解析的xml串
//参数2:随便
//参数3:错误信息
GDataXMLDocument *doc = [[GDataXMLDocument alloc] initWithData:data options:0 error:nil];
//2.获取文件的根节点
GDataXMLElement *rootElement = [doc rootElement];
//3.进一步搜索所有的子节点
//返回一个装满了student节点(GDataXMLElement对象)的数组
NSArray *array = [rootElement elementsForName:@ "student" ];
self.array = [NSMutableArray array];
//4.遍历数组,把student节点的每个子节点取出来
for (GDataXMLElement *element in array) {
Student *stu = [[Student alloc] init];
GDataXMLElement *nameElement = [[element elementsForName:@ "name" ]lastObject];
//从name节点中取值
NSString *name = [nameElement stringValue];
//给学生对象的属性赋值
stu.name = name;
//把学生对象添加到数组中-----------其他的雷同
[self.array addObject:stu];
[stu release];
}
} @end |
1
2
3
4
5
6
7
8
9
|
Student.h #import <Foundation/Foundation.h> @interface Student : NSObject @property (nonatomic , retain)NSString *number; @property (nonatomic , retain)NSString *name; @property (nonatomic , retain)NSString *sex; @property (nonatomic , copy)NSString *phone; @end |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#import "Student.h" @implementation Student - (void)dealloc { [_name release];
[_number release];
[_sex release];
[_phone release];
[ super dealloc];
} //当这个类的对象被NSLog输出时候,系统会先调用这个方法,如果这个方法被重写,就直接输出重写的内容,否则就输出系统默认的内容 - (NSString *)description { return [NSString stringWithFormat:@ "name:%@ sex:%@ phone:%@ number:%@" , self.name, self.sex, self.phone, self.number];
} @end |
1
2
3
4
5
6
7
8
|
<?xml version= "1.0" encoding= "UTF-8" ?>
<employees> <employee> <name>ddviplinux</name> <sex>m</sex> <age>30</age> </employee> </employees> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
public void parserXml(String fileName) { try {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse(fileName);
NodeList employees = document.getChildNodes();
for (int i = 0; i < employees.getLength(); i++) {
Node employee = employees.item(i);
NodeList employeeInfo = employee.getChildNodes();
for (int j = 0; j < employeeInfo.getLength(); j++) {
Node node = employeeInfo.item(j);
NodeList employeeMeta = node.getChildNodes();
for (int k = 0; k < employeeMeta.getLength(); k++) {
System.out.println(employeeMeta.item(k).getNodeName() + ":" + employeeMeta.item(k).getTextContent());
}
}
}
System.out.println( "解析完毕" );
} catch (Exception e) {
System.out.println(e.getMessage());
}
} |
1
2
3
4
5
6
7
8
9
10
|
public void parserXml(String fileName) { SAXParserFactory saxfac = SAXParserFactory.newInstance();
try {
SAXParser saxparser = saxfac.newSAXParser();
InputStream is = new FileInputStream(fileName);
saxparser.parse(is, new MySAXHandler());
} catch (Exception e) {
e.printStackTrace();
}
} |
相关推荐
DOM(Document Object Model)解析和SAX(Simple API for XML)解析是两种常见的XML文档解析方式,它们在处理XML数据时有不同的策略和优缺点。 DOM解析是一种基于树型结构的XML解析方法。当一个XML文档被DOM解析器...
在提供的压缩包中,包含了关于这三种解析方式的代码示例,你可以参考这些代码了解如何在Java环境中使用DOM、SAX和DOM4J进行XML解析。通过阅读和理解这些示例,你可以更好地掌握XML解析技术,并根据项目需求选择合适...
在处理XML文档时,有两大主流解析方式:SAX(Simple API for XML)和DOM(Document Object Model)。这两种解析方式各有特点,适用于不同的场景。 1. SAX解析: SAX解析是一种事件驱动的解析方法,它逐行读取XML...
Android系统提供了三种主要的XML解析方式:DOM(Document Object Model)、PULL(Pull Parser)和SAX(Simple API for XML)。每种方法都有其独特的特性和应用场景,下面将详细介绍这三种XML解析方式。 1. DOM解析...
SAX解析器是一种基于事件驱动的解析方式,它不会一次性加载整个XML文档,而是逐行读取并触发相应的事件,如开始元素、结束元素、字符数据等。这种方式节省了内存,适合处理大型XML文件,但不支持随机访问,且需要...
XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于数据交换、配置文件以及文档存储等领域。...理解这两种解析方式的工作原理和优缺点,可以帮助我们更好地利用XML这一强大的数据交换工具。
在Java编程中,dom4j库提供了对这两种解析方式的支持。 **DOM解析**: DOM解析器将整个XML文档加载到内存中,创建一个树形结构,允许开发者通过节点遍历整个文档。虽然DOM提供了一种方便的方式来访问和修改XML文档...
这三种解析方式各有优劣,选择哪种取决于具体需求。DOM适合需要频繁随机访问或修改XML数据的场景;SAX适用于处理大文件或内存受限的情况;而PULL解析则提供了更灵活的控制,适合资源有限的环境。 在实际应用中,...
Java 解析 XML 文件的 DOM 和 SAX 方式是指在 Java 中使用 Document Object Model(DOM)和 Simple API for XML(SAX)两种方式来解析 XML 文件的技术。下面将详细介绍这两种方式的原理、实现和优缺点。 DOM 方式 ...
在Java中,处理XML文件主要有两种解析器:DOM(Document Object Model)和SAX(Simple API for XML)。这两种解析方式各有特点,适用于不同的场景。 1. DOM解析: DOM解析器将整个XML文档加载到内存中,构建一个树...
JDK(Java Development Kit)提供了两种内置的XML解析器:DOM(Document Object Model)和SAX(Simple API for XML),它们各有特点,适用于不同的场景。 1. DOM解析XML: DOM解析器将整个XML文档加载到内存中,...
本文将详细介绍XML解析文件的两种主要方式:SAX(Simple API for XML)和DOM(Document Object Model)。 **1. DOM解析** DOM解析方式是将整个XML文档加载到内存中,构建一个树形结构,称为DOM树。这个树的每个...
2. SAX解析器:SAX是一种事件驱动的解析方式,它不会将整个XML文档加载到内存,而是逐行读取并触发相应的事件处理器,如开始元素、结束元素等。这种方式节省了内存,适合处理大型XML文件,但操作起来相对复杂,不...
DOM(Document Object Model)是W3C推荐的一种解析XML的标准方法,它将整个XML文档加载到内存中,形成一棵树形结构,允许开发者通过节点遍历来访问和修改XML内容。DOM4J提供了一套灵活且强大的API,包括XPath支持,...
在C#中处理XML时,有两种主要的解析方法:DOM(Document Object Model)和SAX(Simple API for XML)。 1. DOM解析: DOM是一种将整个XML文档加载到内存中的解析方式,它构建了一个树形结构来表示XML文档,允许...
- 可能还包括对比DOM和SAX解析的性能测试,以及在不同场景下选择哪种解析方式的建议。 通过学习这些示例,开发者可以更好地理解XML解析原理,熟练掌握Java处理XML的技巧,提升软件开发中的数据处理能力。
SAX是一种基于事件驱动的解析器,它不会一次性加载整个XML文档到内存,而是逐行读取,当遇到某个元素、属性或其他结构时,会触发相应的事件处理器方法。这种方式适用于处理大型XML文档,因为它占用的内存较小。然而...
下面将详细介绍这三种解析方式及其在Android中的应用。 1. SAX解析: SAX(Simple API for XML)是一种基于事件驱动的解析方式。它不会一次性加载整个XML文档到内存,而是逐行读取,当遇到特定的XML元素时(如开始...
SAX(Simple API for XML)是一种基于事件驱动的解析方式,它不会一次性加载整个XML文档,而是逐行读取,当遇到文档的某个部分(如开始标签、结束标签等)时,触发相应的事件回调。这种方式内存占用小,适合处理大...