iOS文件解析之XML解析

XML概论

XML是指可扩展标记语言(EXtensible Markup Language)。与HTML类似,也是一种使用标签的标记语言。
例如:

<?xml version="1.0" encoding="utf-8"?>//指明了XML的版本号和编码方式
<rss version ="2.0">//RSS(简易信息聚合)是一种消息来源格式规范 version是rss的一个属性
<book>
    <item>
        <bookname>《西游记》</bookname>
        <author>吴承恩</author>
        <price>100</price>
    </item>

    <item>
        <bookname>《水浒传》</bookname>
        <author>施耐庵</author>
        <price>100</price>
    </item>

    <item>
        <bookname>《三国演义》</bookname>
        <author>罗贯中</author>
        <price>100</price>
    </item>

    <item>
        <bookname>《红楼梦》</bookname>
        <author>曹雪芹</author>
        <price>100</price>
    </item>

</book>

XML语法:
所有的XML文档都必须有一个根元素。
所有的XML都必须有一个结束标签。
所有的XML元素都必须正确嵌套。
标签区分大小写。

XML解析

解析XML即将XML文件中所包含的数据信息提取并展示。iOS开始中有两种主要的解析器:DOM和SAX。

1、DOM(Document object model)

DOM是以层次结构组织的节点或信息片段的集合。这个层次结构允许开发人员在树中寻找特定信息。分析该程序通常需要加载整个文档和构造层次结构,然后才能开始工作。他允许应用程序对数据和结构做出更改,但是通常需要加载整个XML文档来构造层次结构,消耗资源很大。

2、SAX(Simple API for XML)

SAX处理的优点非常类似于流媒体的优点。分析能够立即开始,而不是等待所有的数据被处理。而且,由于应用程序只是在读取数据时检查数据,因此不需要将数据存储在内存走。这对大型文档来说是个巨大的优点。事实上,应用程序甚至不必解析整个文档;他可以在某个条件得到满足时停止解析。一般来说,SAX还比它的替代者DOM快很多。

XML解析库

一般在iOS平台下,比较常用的XML解析类库有如下几种:
1、NSXMLParser,这是一个SAX方式解析XML的类库,默认包含在iOS SDK中,使用也比较简单。
2、libxml2,是一套默认包含在iOS SDK中的开源类库,它是基于C语言的API,所以使用起来可能不如NSXML方便。这套类库同时支持DOM和SAX解析,libxml2的SAX解析非常酷,因为可以边读边解析,尤其是从网上下载一个很大的XML文件,就可以一般下载一边对已经下载好的内容进行解析,极大的提高了解析效率。
3、TBXML
4、TouchXML
5、KissXML
6、TinyXML
7、GDataXML,这是一套Google开发的DOM方式XML解析类库,支持读取和修改XML文档。

使用NSXMLParser解析XML文档

iOS SDK的NSXMLParser解析是采用SAX方式来解析XML格式文档。NSXMLParser在处理XML文档的过程中当遇到一些要素(元素,属性,CDATA块,评论等)时会通知它的委托,而自身不对解析的要素进行任何处理,全权委托给NSXMLParserDelegate处理。

一、构造NSXMLParser对象并设置代理

    //获取XML文件路径
    NSString* path = [[NSBundle mainBundle] pathForResource:@"book" ofType:@"xml"];
    //将文件内容提取并存储在缓冲区
    NSData* data = [[NSData alloc] initWithContentsOfFile:path];
    //初始化NSXMLParser对象
    NSXMLParser* parser = [[NSXMLParser alloc] initWithData:data];
    parser.delegate =self;
    [parser parse];

二、调用NSXMLParserDelegate回调函数

//开始解析文档时调用
- (void)parserDidStartDocument:(NSXMLParser *)parser{

}
//解析遇到开始标签
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(nullable NSString *)namespaceURI qualifiedName:(nullable NSString *)qName attributes:(NSDictionary<NSString *, NSString *> *)attributeDict{

}
//当解析器遇到开始标签和结束标签之间的字符时,调用这个方法
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{

}
//解析遇到结束标签
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(nullable NSString *)namespaceURI qualifiedName:(nullable NSString *)qName{

}
//解析结束
- (void)parserDidEndDocument:(NSXMLParser *)parser{

}

XML第三方库/GDataXML解析

GDataXMLNode是Google提供的用于XML数据处理的类集。该类集对libxml2–DOM处理方式进行了封装,能对较小或中等的xml文档进行读写操作且支持XPath语法。

配置GDataXML步骤:

1.下载GDataXML库文件
2.解压缩文件,并且将其中的GDataXMLNode.h 和 GDataXMLNote.m文件拖到项目中
3.选中项目,选中”Build Settings” 标签页
4.将Build Settings页中,顶部的”Basic”标签切换到”ALL”
5.找到”Paths\Header Search Paths”项,并添加”/usr/include/libxml2”到列表中
6.找到”Linking\Other Linker Flags”项,并添加”-lxml2”到列表中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值