两种XML解析方式NSXMLParser和GDataXMLNode
2012-09-01 20:49
453 查看
iPhone中两种XML解析方式NSXMLParser和GDataXMLNode是本文要介绍的内容,很详细的介绍了NSXMLParser和GDataXMLNode这两种方式,常用的解析XML的方式分为两种,它们基于不同的API:
1.Tree-based API:这种API的处理方式是将XML的结构看成是树,然后把树的各部分看成一个对象来处理,这就是我们说的DOM (Document Object Model)方式 。在iPhone的SDK里包含了一个libxml2的框架(Framework)就能进行DOM解析方式 。Google的GDataXML也是基于libxml2的,因此在使用GDataXML之前,你需要先导入libxml2 。
2.Event-driven API:这种方式通常用于解析基于的事件,SAX解析方式就是这种解析方式的代表 。在iPhone开发的,也可以利用这种方式来解析XML,不过这可不是Iphone SDK的属性啊,而是Objective-C的功能 。在Objectvie-C种有专门解析XML的类NSXMLParser 。
NSXMLParser和CGataXML的使用方法:
NSXMLParser解析方式
NSXMLParser解析XML的主要工作都是靠它的代理(NSXMLParserDelegate)来实现的 。
- (void)viewDidLoad {
[super viewDidLoad];
//........
NSXMLParser *parser = [[NSXMLParser alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://lab.xxxxxx.com/xxx/xxx.xml"]];
[parser setDelegate:self];
[parser parse];
for (int i = 0; i < [newsArray count]; i++) {
NSLog(@"%@",[newsArray objectAtIndex:i]);
}
}
就这么几句,就开始解析了,怎样得到XML里面的数据呢?
那就去代理里面找吧!
#pragma mark NSMXLParser Delegate Methods
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict{
if ([elementName isEqualToString:@"docTitle"]) {
if (!newsArray) {
newsArray = [[NSMutableArray alloc] init];
return;
}
}
}
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{
if (!currentString) {
currentString = [[NSMutableString alloc] init];
}
[currentString appendString:string];
[currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]];
}
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName{
if ([elementName isEqualToString:@"docTitle"]) {
[newsArray addObject:currentString];
}
[currentString release];
currentString = nil;
}
先说一下程序运行的流程,当parser初始化并执行parse语句时([parser parse]),程序会跳到代理方法里面走第一个代理方法 。第一个代理方法会将整个xml遍历一遍,并识别xml里面的元素名称(elementName),在发现有我想找的信息(docTitle)时,创建一个数组用来存储这些信息,当然第一个代理还没开始存储信息 。
接下来会走第二个代理,它会把第一个代理中我们相要找的信息存储在currentString中 。其中我增加了一个对获取的字符串的处理语句 [currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]],它可以将字符串开始的空格和换行附去掉(因为常会遇到xml文件格式不太标准的) 。
最后是第三个代理方法,把我们获取的信息存储到数组中 。
当然程序运行过程中这三步的顺序并不是这么严格的执行的,而且会反复的执行,但是大致的处理过程是这样的 。
DOM解析方式之GDataXMLNode
GDataXMLNode是基于libxml2的第三方文件,功能比较强大 。
NSError* error = nil;
NSString *documentStr = [[NSString alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://www.xxxx.com/x/xxx.xml"]
encoding:NSUTF8StringEncoding error:&error];
GDataXMLDocument* XMLdocument = [[GDataXMLDocument alloc] initWithXMLString:documentStr options:0 error:&error];
[documentStr release];
GDataXMLElement* rootElement = [XMLdocument rootElement];
NSArray *newsArray = [rootElement elementsForName:@"docTitle"];
for (int i = 0; i < [newsArray count]; i++) {
NSLog(@"%@",[[newsArray objectAtIndex:i] stringValue]);
}
就这么几句,功能和上面的NSXMLParser,当然这个数组里存储的是GDataXMLElement的对象而不是字符串 。
在DOM解析方式中,先将XML文件或链接转化成对象,这里是GDataXMLDocument对象,然后该对象里面的每一部分都看成一个对象,如rootElement是一个GDataXMLElement对象,它是整个XML树的根,包含了该XML的所有信息 。我们直接在rootElement下找名为:docTitle的对象,把它放在数组里面(因为这样的对象可能不止一个) 。我们要取docTitle对象里面的内容hello iPhone,该对象的stringValue就是 。
原文:http://www.cnblogs.com/pengyingh/articles/2342974.html
1.Tree-based API:这种API的处理方式是将XML的结构看成是树,然后把树的各部分看成一个对象来处理,这就是我们说的DOM (Document Object Model)方式 。在iPhone的SDK里包含了一个libxml2的框架(Framework)就能进行DOM解析方式 。Google的GDataXML也是基于libxml2的,因此在使用GDataXML之前,你需要先导入libxml2 。
2.Event-driven API:这种方式通常用于解析基于的事件,SAX解析方式就是这种解析方式的代表 。在iPhone开发的,也可以利用这种方式来解析XML,不过这可不是Iphone SDK的属性啊,而是Objective-C的功能 。在Objectvie-C种有专门解析XML的类NSXMLParser 。
NSXMLParser和CGataXML的使用方法:
NSXMLParser解析方式
NSXMLParser解析XML的主要工作都是靠它的代理(NSXMLParserDelegate)来实现的 。
- (void)viewDidLoad {
[super viewDidLoad];
//........
NSXMLParser *parser = [[NSXMLParser alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://lab.xxxxxx.com/xxx/xxx.xml"]];
[parser setDelegate:self];
[parser parse];
for (int i = 0; i < [newsArray count]; i++) {
NSLog(@"%@",[newsArray objectAtIndex:i]);
}
}
就这么几句,就开始解析了,怎样得到XML里面的数据呢?
那就去代理里面找吧!
#pragma mark NSMXLParser Delegate Methods
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict{
if ([elementName isEqualToString:@"docTitle"]) {
if (!newsArray) {
newsArray = [[NSMutableArray alloc] init];
return;
}
}
}
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{
if (!currentString) {
currentString = [[NSMutableString alloc] init];
}
[currentString appendString:string];
[currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]];
}
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName
namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName{
if ([elementName isEqualToString:@"docTitle"]) {
[newsArray addObject:currentString];
}
[currentString release];
currentString = nil;
}
先说一下程序运行的流程,当parser初始化并执行parse语句时([parser parse]),程序会跳到代理方法里面走第一个代理方法 。第一个代理方法会将整个xml遍历一遍,并识别xml里面的元素名称(elementName),在发现有我想找的信息(docTitle)时,创建一个数组用来存储这些信息,当然第一个代理还没开始存储信息 。
接下来会走第二个代理,它会把第一个代理中我们相要找的信息存储在currentString中 。其中我增加了一个对获取的字符串的处理语句 [currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]],它可以将字符串开始的空格和换行附去掉(因为常会遇到xml文件格式不太标准的) 。
最后是第三个代理方法,把我们获取的信息存储到数组中 。
当然程序运行过程中这三步的顺序并不是这么严格的执行的,而且会反复的执行,但是大致的处理过程是这样的 。
DOM解析方式之GDataXMLNode
GDataXMLNode是基于libxml2的第三方文件,功能比较强大 。
NSError* error = nil;
NSString *documentStr = [[NSString alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://www.xxxx.com/x/xxx.xml"]
encoding:NSUTF8StringEncoding error:&error];
GDataXMLDocument* XMLdocument = [[GDataXMLDocument alloc] initWithXMLString:documentStr options:0 error:&error];
[documentStr release];
GDataXMLElement* rootElement = [XMLdocument rootElement];
NSArray *newsArray = [rootElement elementsForName:@"docTitle"];
for (int i = 0; i < [newsArray count]; i++) {
NSLog(@"%@",[[newsArray objectAtIndex:i] stringValue]);
}
就这么几句,功能和上面的NSXMLParser,当然这个数组里存储的是GDataXMLElement的对象而不是字符串 。
在DOM解析方式中,先将XML文件或链接转化成对象,这里是GDataXMLDocument对象,然后该对象里面的每一部分都看成一个对象,如rootElement是一个GDataXMLElement对象,它是整个XML树的根,包含了该XML的所有信息 。我们直接在rootElement下找名为:docTitle的对象,把它放在数组里面(因为这样的对象可能不止一个) 。我们要取docTitle对象里面的内容hello iPhone,该对象的stringValue就是 。
原文:http://www.cnblogs.com/pengyingh/articles/2342974.html
相关文章推荐
- iPhone中两种XML解析方式NSXMLParser和GDataXMLNode
- iOS-XML文件解析(原生NSXMLParser和GDataXML两种解析方式)
- iOS-XML文件解析(原生NSXMLParser和GDataXML两种解析方式)
- xml的两种解析方式
- kxml解析 xml的两种方式
- JSON与XML的区别比较以及xml两种解析方式的比较
- Java解析XMl的两种方式,集合操作时NoSuchElementException异常重现
- XML解析的两种方式DOM和SAX
- 通过AJAX的JS、JQuery两种方式解析XML示例介绍
- java 两种xml解析方式
- XML解析的两种解析方式
- 通过AJAX的JS、JQuery两种方式解析XML示例介绍
- Android/Java XML数据格式解析的两种方式
- XML的两种解析方式逐行解析(SAX解析)节点解析(DOM解析); 推荐
- XML解析的两种方式:DOM方式和SAX方式
- Xml解析的两种方式
- xml--解析01--xml的解析的两种方式Dom和SAX
- XML常见的两种解析方式总结
- XML的两种解析方式Dom和SAX的区别
- Adroid开发之解析xml数据的两种方式