iOS-XML解析

SAX和DOM,NSXMLParser和GDataXML和ONOXML

基于不同的API有两种不同的解析方式:

1.Tree-based API:这种API的处理方式是将XML的结构看成是树,然后把树的各部分看成一个对象来处理,这就是我们说的DOM (Document Object Model)方式  。在iPhone的SDK里包含了一个libxml2的框架(Framework)就能进行DOM解析方式  。

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

NSXMLParser和CGataXML的使用方法:

1、NSXMLParser解析XML的主要工作都是靠它的代理(NSXMLParserDelegate)来实现的  。

NSXMLParser *parser = [[NSXMLParser alloc] initWithContentsOfURL:[NSURL URLWithString:@"http://lab.xxxxxx.com/xxx/xxx.xml"]];// 创建解析对象

[parser setDelegate:self];

[parser parse];

然后再实现三个代理方法:

1>  - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict;// 将整个XML文件遍历一遍,并识别xml里面的元素名称(elementName),在发现有我想找的信息(docTitle)时,创建一个数组用来存储这些信息,当然第一个代理还没开始存储信息  。

2>  -(void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string;// 把第一个代理中我们相要找的信息存储在currentString中。

[currentString setString:[currentString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]];// 该方法可以将字符串开始的空格和换行附去掉

3>- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName;//把获取的信息存储到数组中

2.DOM解析方式之 GDataXMLNode是基于libxml2的第三方文件,功能比较强大  。

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];

GDataXMLElement* rootElement = [XMLdocument rootElement];

NSArray *newsArray = [rootElement elementsForName:@"docTitle"];

在DOM解析方式中,先将XML文件或链接转化成对象,这里是GDataXMLDocument对象,然后该对象里面的每一部分都看成一个对象,如rootElement是一个GDataXMLElement对象,它是整个XML树的根,包含了该XML的所有信息  。

你可能感兴趣的:(iOS-XML解析)