iPhone中兩種XML解析方式NSXMLParser和GDataXMLNode
iPhone中兩種XML解析方式NSXMLParser和GDataXMLNode是本文要介紹的內(nèi)容,很詳細(xì)的介紹了NSXMLParser和GDataXMLNode這兩種方式,常用的解析XML的方式分為兩種,它們基于不同的API:
1.Tree-based API:這種API的處理方式是將XML的結(jié)構(gòu)看成是樹,然后把樹的各部分看成一個(gè)對(duì)象來(lái)處理,這就是我們說(shuō)的DOM (Document Object Model)方式。在iPhone的SDK里包含了一個(gè)libxml2的框架(Framework)就能進(jìn)行DOM解析方式。Google的GDataXML也是基于libxml2的,因此在使用GDataXML之前,你需要先導(dǎo)入libxml2。
2.Event-driven API:這種方式通常用于解析基于的事件,SAX解析方式就是這種解析方式的代表。在iPhone開發(fā)的,也可以利用這種方式來(lái)解析XML,不過(guò)這可不是Iphone SDK的屬性啊,而是Objective-C的功能。在Objectvie-C種有專門解析XML的類NSXMLParser。
NSXMLParser和CGataXML的使用方法:
NSXMLParser解析方式
NSXMLParser解析XML的主要工作都是靠它的代理(NSXMLParserDelegate)來(lái)實(shí)現(xiàn)的。
- - (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里面的數(shù)據(jù)呢?
那就去代理里面找吧!
- #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;
- }
先說(shuō)一下程序運(yùn)行的流程,當(dāng)parser初始化并執(zhí)行parse語(yǔ)句時(shí)([parser parse]),程序會(huì)跳到代理方法里面走***個(gè)代理方法。***個(gè)代理方法會(huì)將整個(gè)xml遍歷一遍,并識(shí)別xml里面的元素名稱(elementName),在發(fā)現(xiàn)有我想找的信息(docTitle)時(shí),創(chuàng)建一個(gè)數(shù)組用來(lái)存儲(chǔ)這些信息,當(dāng)然***個(gè)代理還沒開始存儲(chǔ)信息。
接下來(lái)會(huì)走第二個(gè)代理,它會(huì)把***個(gè)代理中我們相要找的信息存儲(chǔ)在currentString中。其中我增加了一個(gè)對(duì)獲取的字符串的處理語(yǔ)句 [currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]],它可以將字符串開始的空格和換行附去掉(因?yàn)槌?huì)遇到xml文件格式不太標(biāo)準(zhǔn)的)。
***是第三個(gè)代理方法,把我們獲取的信息存儲(chǔ)到數(shù)組中。
當(dāng)然程序運(yùn)行過(guò)程中這三步的順序并不是這么嚴(yán)格的執(zhí)行的,而且會(huì)反復(fù)的執(zhí)行,但是大致的處理過(guò)程是這樣的。
DOM解析方式之GDataXMLNode
GDataXMLNode是基于libxml2的第三方文件,功能比較強(qiáng)大。
- 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,當(dāng)然這個(gè)數(shù)組里存儲(chǔ)的是GDataXMLElement的對(duì)象而不是字符串。
在DOM解析方式中,先將XML文件或鏈接轉(zhuǎn)化成對(duì)象,這里是GDataXMLDocument對(duì)象,然后該對(duì)象里面的每一部分都看成一個(gè)對(duì)象,如rootElement是一個(gè)GDataXMLElement對(duì)象,它是整個(gè)XML樹的根,包含了該XML的所有信息。我們直接在rootElement下找名為:docTitle的對(duì)象,把它放在數(shù)組里面(因?yàn)檫@樣的對(duì)象可能不止一個(gè))。我們要取docTitle對(duì)象里面的內(nèi)容<docTitle>hello iPhone</docTitle>,該對(duì)象的stringValue就是。
小結(jié):iPhone中兩種XML解析方式NSXMLParser和GDataXMLNode的內(nèi)容介紹完了,希望本文對(duì)你有所幫助!