介绍两种常用的XML解析方式(NSXMLParser & GDataXMLNode)

介绍两种常用的XML解析方式(NSXMLParser & GDataXMLNode)

 

常用的解析XML的方式分为两种,它们基于不同的API

1.Tree-based API:这种API的处理方式是将XML的结构看成是树,然后把树的各部分看成一个对象来处理,这就是我们说的DOM (Document Object Model)方式。在iPhoneSDK里包含了一个libxml2的框架(Framework)就能进行DOM解析方式。GoogleGDataXML也是基于libxml2的,因此在使用GDataXML之前,你需要先导入libxml2

 

2.Event-driven API:这种方式通常用于解析基于的事件,SAX解析方式就是这种解析方式的代表。在iPhone开发的,也可以利用这种方式来解析XML,不过这可不是Iphone SDK的属性啊,而是Objective-C的功能。在Objectvie-C种有专门解析XML的类NSXMLParser

 

NSXMLParserCGataXML的使用方法:

 

  1. 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文件格式不太标准的)。

最后是第三个代理方法,把我们获取的信息存储到数组中。

当然程序运行过程中这三步的顺序并不是这么严格的执行的,而且会反复的执行,但是大致的处理过程是这样的。

 

  1. 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对象里面的内容<docTitle>hello iPhone</docTitle>,该对象的stringValue就是。

转载于:https://www.cnblogs.com/tracy-e/archive/2010/08/29/1812075.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值