XML解析常见的两种方式:DOM解析和SAX解析
DOM解析
DOM:Document Object Model(文档对象类型).解析XML时,读入整个XML文档并构建一个驻留内存的树结构(节点树),通过遍历数结构可以检索任意XML节点,读取它的属性和值,而且通常情况下,可以借助XPath,直接查询XML节点. 进行DOM方式解析数据需要使用一个第三方的类GDataXMLNode GDataXMLNode是Google提供的开源XML解析类,对libxml2.tbd进行了Objective-C的封装,能对较小或者中等的xml文档进行读写操作且支持XPath语法. GDataXMLNode使用方法:1 获取GDataXMLNode.h/m文件,将GDataXMLNode.h/m文件添加到工程中.
2 向工程中添加'libxml2.tbd'动态库.
3 在工程的”Build Settings”页中找到”Header Search Path”项,添加”/usr/include/libxml2”.
4 导入”GDataXMLNode.h”文件到头文件中,如工程能编译通过,则说明GDataXMLNode添加成功.
(GDataXMLNode第三方可在GitHub搜索下载)
解析
-(void)xmlDOMMethed{
//盛放所有的字典
self.sourceArray = [NSMutableArray array];
//setp1.得到需要解析的数据
NSString *xmlPath = [[NSBundle mainBundle] pathForResource:@"XMLDemo" ofType:@"xml"];
//step2.转换为NSData类型
NSData *xmlData = [NSData dataWithContentsOfFile:xmlPath];
//step3.1 构建document文档对象(options预留参数)
GDataXMLDocument *doc = [[GDataXMLDocument alloc] initWithData:xmlData options:0 error:nil];
//step3.2 找到根节点(students)
GDataXMLElement *rootElement = [doc rootElement];
//step3.3 找到根节点的所有子节点
NSArray *allSubNotes = [rootElement elementsForName:@"student"];
//step3.3 找到student节点的所有子节点
for (GDataXMLElement *item in allSubNotes) {
//每次循环开始的时候,说明是一个新的student节点,我们需要字典来盛放它所有的值
NSMutableDictionary *studentDic = [NSMutableDictionary dictionary];
//得到name节点
NSArray *nameArray = [item elementsForName:@"name"];
GDataXMLElement *nameElement = [nameArray objectAtIndex:0];
NSString *name = [nameElement stringValue];
[studentDic setObject:name forKey:@"name"];
//取出age
NSArray *ageArray = [item elementsForName:@"age"];
GDataXMLElement *ageElement = [ageArray objectAtIndex:0];
NSString *age = [ageElement stringValue];
[studentDic setObject:age forKey:@"age"];
//取出sex
NSArray *sexArray = [item elementsForName:@"sex"];
GDataXMLElement *sexElement = [sexArray objectAtIndex:0];
NSString *sex = [sexElement stringValue];
[studentDic setObject:sex forKey:@"sex"];
//把student字典添加到数组中
[self.sourceArray addObject:studentDic];
}
NSLog(@"%@",self.sourceArray);
}
写入










