一、介绍 |
dom是w3c指定的一套规范标准,核心是按树形结构处理数据,dom解析器读入xml文件并在内存中建立一个结构一模一样的“树”,这树各节点和xml各标记对应,通过操纵此“树”来处理xml中的文件。xml文件很大时,建立的“树”也会大,所以会大量占用内存。
sax解析器核心是事件处理机制。例如解析器发现一个标记的开始标记时,将所发现的数据会封装为一个标记开始事件,并把这个报告给事件处理器,事件处理器再调用方法(startElement)处理发现的数据。下面我们尝试一下SAX和DOM解析:
XML格式如下:
二、SAX: |
1、我们用SAX解析的时候用的是苹果自带的NSXMLParser,首先初始化一个解析器,通过设置代理开始解析,代码如下:
//初始化路径
NSString * path=[[NSBundle mainBundle] pathForResource:@"Test.xml" ofType:nil];
NSData * data=[NSData dataWithContentsOfFile:path];
//初始化解析器
NSXMLParser * parser=[[NSXMLParser alloc] initWithData:data];
//设置代理
parser.delegate=self;
//开始解析
[parser parse];
2、通过代理方法开始解析,由于sax方式是事件驱动,因此解析是按照顺序解析,如果想获取标签的数据我们需要监控每个步骤的解析情况,因此系统提供了代理方法给我们,下面便是常用代理方法:
//开始加载文档
- (void)parserDidStartDocument:(NSXMLParser *)parser{} //结束加载文档
- (void)parserDidEndDocument:(NSXMLParser *)parser{ }
//开始解析标签
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict{
}
//标签解析结束
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName{
}
//读取标签之间的文本
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{
content=string;
}
3、XM有两种存值方式,一个是属性,一个是标签之间的文本。如果我们想获取属性需要在代理方法中获取,如图:
如果是获取标签之间的文本需要采用代理方法如图:
总结:通过给定代理方法的结合我们便可以轻松的获取XML的内容
三、DOM |
1、我们用DOM解析的时候用的是第三方框架GDataXMLNode,该框架为动态库。我们需要引入如下:
同时需要引入第三方支持框架:
DOM解析相对于SAX稍微简单一些,DOM 首先将整个文件全部放入内存。然后在内存中以二叉树的形式获取里面的元素内容。
涉及到的主要类:
GDataXMLDocument //整个文档
GDataXMLElement //节点对象
GDataXMLNode //属性节点对象
我们可以用以下方法解析数据
//初始化
//将文件加入到内存
GDataXMLDocument * document=[[GDataXMLDocument alloc] initWithData:data options:0 error:nil];
//获取根元素
GDataXMLElement * root=document.rootElement;
//获取所有该名称的子节点
-(NSArray *)elementsForName:(NSString *)name;
//根据名称获取属性值
-(GDataXMLNode*)attributeForName:(NSString *)name;
这样我们便可以轻松解析并且获取XMl的值了,如图: