NSXMLParser和GDataXMLNode兩種解析方式


 iPhone中兩種XML解析方式NSXMLParserGDataXMLNode是本文要介紹的內容,很詳細的介紹了NSXMLParserGDataXMLNode這兩種方式,常用的解析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)來實現的  。

  1. - (void)viewDidLoad {  
  2. [super viewDidLoad];  
  3. //........  
  4. NSXMLParser *parser = [[NSXMLParser alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://lab.xxxxxx.com/xxx/xxx.xml"]];  
  5. [parser setDelegate:self];  
  6. [parser parse];   
  7. for (int i = 0; i < [newsArray count]; i++) {  
  8. NSLog(@"%@",[newsArray objectAtIndex:i]);  
  9. }  

  就這么幾句,就開始解析了,怎樣得到XML里面的數據呢?

  那就去代理里面找吧!

  1. #pragma mark NSMXLParser Delegate Methods  
  2. - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName   
  3. namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict{  
  4. if ([elementName isEqualToString:@"docTitle"]) {  
  5. if (!newsArray) {  
  6. newsArray = [[NSMutableArray alloc] init];  
  7. return;  
  8. }  
  9. }  
  10. }  
  11. - (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{  
  12.  
  13. if (!currentString) {  
  14. currentString = [[NSMutableString alloc] init];  
  15. }  
  16. [currentString appendString:string];  
  17. [currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]];  
  18. }  
  19. - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName   
  20. namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName{  
  21. if ([elementName isEqualToString:@"docTitle"]) {  
  22. [newsArray addObject:currentString];  
  23. }  
  24. [currentString release];  
  25. currentString = nil;  

  先說一下程序運行的流程,當parser初始化並執行parse語句時([parser parse]),程序會跳到代理方法里面走第一個代理方法  。第一個代理方法會將整個xml遍歷一遍,並識別xml里面的元素名稱(elementName),在發現有我想找的信息(docTitle)時,創建一個數組用來存儲這些信息,當然第一個代理還沒開始存儲信息  。

  接下來會走第二個代理,它會把第一個代理中我們相要找的信息存儲在currentString中  。其中我增加了一個對獲取的字符串的處理語句 [currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]],它可以將字符串開始的空格和換行附去掉(因為常會遇到xml文件格式不太標准的)  。

  最后是第三個代理方法,把我們獲取的信息存儲到數組中  。

  當然程序運行過程中這三步的順序並不是這么嚴格的執行的,而且會反復的執行,但是大致的處理過程是這樣的  。

  DOM解析方式之GDataXMLNode

  GDataXMLNode是基於libxml2的第三方文件,功能比較強大  。

  1. NSError* error = nil;  
  2. NSString *documentStr = [[NSString alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://www.xxxx.com/x/xxx.xml"] 
  3. encoding:NSUTF8StringEncoding error:&error];  
  4. GDataXMLDocument* XMLdocument = [[GDataXMLDocument alloc] initWithXMLString:documentStr options:0 error:&error];  
  5. [documentStr release];  
  6. GDataXMLElement* rootElement = [XMLdocument rootElement];  
  7. NSArray *newsArray = [rootElement elementsForName:@"docTitle"];  
  8. for (int i = 0; i < [newsArray count]; i++) {  
  9. NSLog(@"%@",[[newsArray objectAtIndex:i] stringValue]);  

  就這么幾句,功能和上面的NSXMLParser,當然這個數組里存儲的是GDataXMLElement的對象而不是字符串  。

  在DOM解析方式中,先將XML文件或鏈接轉化成對象,這里是GDataXMLDocument對象,然后該對象里面的每一部分都看成一個對象,如rootElement是一個GDataXMLElement對象,它是整個XML樹的根,包含了該XML的所有信息  。我們直接在rootElement下找名為:docTitle的對象,把它放在數組里面(因為這樣的對象可能不止一個)  。我們要取docTitle對象里面的內容hello iPhone,該對象的stringValue就是  。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM