Objective-C学习之解析XML

通过soap请求webservice时,返回的数据是XML类型,有时候也需要解析本地的xml数据等,苹果自带类NSXMLParser解析xml还是很方便的,简单轻便

本文以解析本地XML为例,网络获取到的返回值只需转换成NSData型,解析是同理

需要解析的xml文件如下,users.xml

01
<?xml version="1.0" encoding="UTF-8"?>
02
<AllUsers>
03
    <message>用户信息</message>
04
    <user>
05
        <name>芳仔小脚印</name>
06
        <age>10</age>
07
        <school>JiangSu University</school>
08
    </user>
09
    <user>
10
        <name>毒虫</name>
11
        <age>22</age>
12
        <school>NanJing University</school>
13
    </user>
14
    <user>
15
        <name>女神</name>
16
        <age>23</age>
17
        <school>HongKong University</school>
18
    </user>
19
</AllUsers>
我们用一个数组来存放,最终数据结构为

01
(
02
        {
03
        message = "用户信息";
04
    },
05
        {
06
        age = 10;
07
        name = "芳仔小脚印";
08
        school = "JiangSu University";
09
    },
10
        {
11
        age = 22;
12
        name = "毒虫";
13
        school = "NanJing University";
14
    },
15
        {
16
        age = 23;
17
        name = "女神";
18
        school = "HongKong University";
19
    }
20
)
解析步骤

一、声明代理 NSXMLParserDelegate

二、解析

01
// 遇到节点message和user时作为一个字典存放
02
    NSArray *keyElements = [[NSArray alloc] initWithObjects:@"message",@"user", nil];
03
    // 需要解析的字段
04
    NSArray *rootElements = [[NSArray alloc] initWithObjects:@"message",@"name",@"age",@"school", nil];
05
    // 获取xml文件的路径
06
    NSString *xmlPath = [[NSBundle mainBundle] pathForResource:@"users" ofType:@"xml"];
07
    // 转化为Data
08
    NSData *data = [[NSData alloc] initWithContentsOfFile:xmlPath];
09
     
10
    // 初始化
11
    NSXMLParser *xmlParser = [[NSXMLParser alloc] initWithData:data];
12
     
13
    // 代理
14
    xmlParser.delegate = self;
15
    // 开始解析
16
    BOOL flag = [xmlParser parse];
17
    if (flag) {
18
        NSLog(@"解析成功");
19
    }
20
    else{
21
        NSLog(@"解析出错");
22
    }
中间变量,在.m的interface的中定义

1
NSString *currentElement;
2
     
3
    NSString *currentValue;
4
     
5
    NSMutableDictionary *rootDic;
6
     
7
    NSMutableArray *finalArray;
代理方法

01
#pragma - mark 开始解析时
02
-(void)parserDidStartDocument:(NSXMLParser *)parser
03
{
04
    // 用数组存储每一组信息
05
    finalArray = [[NSMutableArray alloc] init];
06
     
07
     
08
}
09
#pragma - mark 发现节点时
10
-(void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
11
{
12
    for(NSString *key in self.keyElements){
13
        if ([elementName isEqualToString:key]) {
14
            // 关键节点开始时,初始化一个字典来存放值
15
            rootDic = nil;
16
             
17
            rootDic = [[NSMutableDictionary alloc] initWithCapacity:0];
18
             
19
        }
20
        else {
21
            for(NSString *element in self.rootElements){
22
                if ([element isEqualToString:element]) {
23
                    currentElement = elementName;
24
                    currentValue = [NSString string];
25
                }
26
            }
27
        }
28
    }
29
     
30
}
31
#pragma - mark 发现节点值时
32
 
33
-(void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
34
{
35
     
36
    if (currentElement) {
37
 
38
        currentValue = string;
39
        [rootDic setObject:string forKey:currentElement];
40
    }
41
     
42
}
43
#pragma - mark 结束节点时
44
-(void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
45    javascript特效
{
46
    if (currentElement) {
47
        [rootDic setObject:currentValue forKey:currentElement];
48
        currentElement = nil;
49
        currentValue = nil;
50
    }
51
    for(NSString *key in self.keyElements){
52
 
53
        if ([elementName isEqualToString:key]) {
54
            // 关键节点结束时,将字典存放在数组中
55
            if (rootDic) {
56
 
57
                [finalArray addObject:rootDic];
58
            }
59
        }
60
    }
61
}
62
#pragma - mark 结束解析
63 http://www.huiyi8.com/jiaoben/
-(void)parserDidEndDocument:(NSXMLParser *)parser
64
{
65
     
66
}
解析完成后,打印出finalArray为

view sourceprint?
01
{
02
        message = "\U7528\U6237\U4fe1\U606f";
03
    },
04
        {
05
        age = 10;
06
        name = "\U82b3\U4ed4\U5c0f\U811a\U5370";
07
        school = "JiangSu University";
08
    },
09
        {
10
        age = 22;
11
        name = "\U6bd2\U866b";
12
        school = "NanJing University";
13
    },
14
        {
15
        age = 23;
16
        name = "\U5973\U795e";
17
        school = "HongKong University";
18
    }
19
)

Objective-C学习之解析XML

时间: 2024-10-01 07:18:03

Objective-C学习之解析XML的相关文章

java 解析 xml 文件

学习下解析 xml 文件,这里用到了 org.dom4j 这个 jar 包,使用 eclipse 没有这个包的小伙伴可以去下个 jar 包,然后复制到项目路径下,右键 jar 包后 build path,add build path 即可. 来引入相关依赖: import java.io.File; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.Elem

iOS SDK中使用NSXMLParser解析XML(iphone网络篇三)

iOS SDK的NSXMLParser解析XML文档是事件驱动模式的,即采用SAX方式来解析XML格式文档.NSXMLParser在处理XML文档的过程中当遇到一些要素(元素.属性.CDATA块.评论等)时会通知它的委托,而自身不对解析的要素进行任何处理,全权委托给NSXMLParserDelegate处理.同时它也会报告错误. 1. 打开一个xml文件,读取内容到NSData中. NSString *path = [[NSBundle mainBundle] pathForResource:@

Android开发学习---使用XmlPullParser解析xml文件

Android中解析XML的方式主要有三种:sax,dom和pull关于其内容可参考:http://blog.csdn.net/liuhe688/article/details/6415593 本文将主要介绍pull解析器解析xml文件,环境为ubuntu 12.04+ intelij 13.1 + android sdk 2.1 一.创建一个XML项目,步骤如下: 二.解析一个xml文件: assets/person.xml <?xml version="1.0" encodi

XML学习笔记(五):使用 jdom和dom4j 解析XML

XML解析的详细分析与jaxp解析XML详见:XML学习笔记(四):使用 DOM和SAX 解析XML 一.JDom 1.创建XML文件: 1)Document类即代表整个XML文档,把生成的 Document 利用 XMLOutputter 类输出即可. 2)映射关系:元素:Element:属性:Attribute:注解:Comment:文本信息:Text: 3)注意:addContent()是追加,setContent()会覆盖. /** * 创建XML * * @throws IOExcep

Android 学习之pull解析Xml

一. PUll解析Xml public static List<Person> xmlParser(InputStream xml) throws Exception { List<Person> persons=null; Person p=null; XmlPullParser parser=Xml.newPullParser(); parser.setInput(xml, "UTF-8"); int event=parser.getEventType();

Java学习之道:详解Java解析XML的四种方法

XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.对于XML本身的语法知识与技术细节,需要阅读相关的技术文献,这里面包括的内容有DOM(Document Object Model),DTD(Document Type Definition),SAX(Simple API for XML),XSD(Xml Schema Definition),XSLT(Extensible Stylesheet Language Transform

javaweb学习总结九(xml解析以及调整JVM内存大小)

一:解析XML文件的两种方式 1:dom,document object model,文档对象模型. 2:sax,simple API for XML. 3:比较dom和sax解析XML文件的优缺点 a:dom 优点:dom解析方式会把xml文件加载到内存中,按照xml的结构解析成dom树,元素.文本.属性都会解析成对象,方便进行增删改查. 缺点:如果xml文件比较大,加载文件内存压力大. b:sax 优点:sax解析方式是一行一行的读取xml文件,所以不会造成内存压力. 缺点:不能进行增删改的

XML学习笔记(二):使用 DOM和SAX 解析XML :

一.XML解析的简介 1.一般来说xml解析的方式有两种,Dom与SAX,且各有优缺点.pull是第三种方法见:pull解析XML 1)DOM:dom对象树 ①.整个XML放入内存,转换为Document对象: ②.每个元素,转换成Element对象 ③.文本,转换成Text对象 ④.属性,转换成Attribute对象 优缺点:元素的CRUD比较简单,但是内存消耗大,大的xml文档不适合. 补充:内存不足时,可以修改参数,调整JVM的内存大小 1.java.lang.OutOfMemoryErr

android学习二十二(使用SAX解析xml)

上一篇博客是使用Pull解析xml文件的,Pull解析方式虽然非常好用,但它并不是我们唯一的选择.SAX解析也是一种特别常用的XML解析方式,虽然它的用法比Pull解析复杂,但在语义方面会更加的清楚. 通常情况下我们都会新建一个类继承自DefaultHandler,并重写父类的五个方法,如下所示: package com.jack.networktest; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import