天天看点

iOS的Plist-XML-JSON数据解析

络上传输数据通用的有XML,JSON等,iOS中也可以用Plist。

要进行数据传输,就要首先进行序列化:

1. 序列化 .   对象转换成二进制流 .( 这个一句话就行 ) 2 . 反序列化 . 二进制流转换为对象 等 . ( 关键要弄清楚这个 )

JSON : ( 和 XML 一样都是用来传数据的 ) 轻量级的数据交换格式 , 正在逐步取代 XML. XML : 结构性的标记语言 , 易读 . 但数据量大 . Plist 偶尔用着玩玩: Mac、iOS中用的多一种格式。

一、应用场景 1、 XML 的应用场景 : XMPP—— 即时通讯, KissXML RSS 目前还有少量的企业在使用 开源的 WebServices ,例如天气预报等 如果设计好 XML 的接口, XML 的解析并不会太复杂

2、 JSON 的应用场景 : ( 数据量小 , 轻量级 ) 移动开发中绝大多数还是使用 JSON 如果自己开发,或者公司后台接口,最好使用 JSON.

二、Plist解析数据 定义一个Plist的格式如下:

iOS的Plist-XML-JSON数据解析

解析代码如下:(在异步线程中进行, 最后得到array) ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39

- (

void

)loadData

{

// 1. url

NSURL *url = [NSURL URLWithString:@

"http://localhost/videos.plist"

];

// 2. request

// timeoutInterval 如果5.0之内没有从服务器返回结果,就认为超时了

NSURLRequest *request = [NSURLRequest requestWithURL:url cachePolicy:0 timeoutInterval:5.0];

// 3. 网络异步请求

[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {

if

(connectionError) {

NSLog(@

"错误 %@"

, connectionError);

return

;

}

// data是一个plist数据, 对data进行反序列化,解析

NSArray *array = [NSPropertyListSerialization propertyListWithData:data options:0 format:NULL error:NULL];

// 刷新数据,在UI线程中更新UI

dispatch_async(dispatch_get_main_queue(), ^{

//.....

});

}];

}

三、XML解析 iOS中XML 解析方式的两种方式(Android中好友pull等)  : 1、 SAX ( SimpleAPI for XML ) 只能读,不能修改 ,只能顺序访问,适合解析大型 XML , 解析速度快 常应用于处理大量数据的 XML ,实现异构系统的数据访问,实现跨平台 从文档的开始通过每一节点移动,定位一个特定的节点 2、 DOM ( DocumentObject   Model ) 不仅能读,还能修改 ,而且能够实现随机访问,缺点是 解析速度慢 ,适合解析小型文档 . 方便操作 . 在内存中生成节点树操作 代价昂贵

XML 解析步骤 : 1、 实例化 NSXMLParser , 传入 从服务器接收的 XML 数据 2、 定义解析器 代理 3、 解析器 解析, 通过解析代理方法完成 XML 数据的解析。

解析 XML 用到的的 代理方法 :

1. 开始解析XML文档

- (void)parserDidStartDocument:

2. 开始解析某个元素,会遍历整个XML,识别元素节点名称,如<video>开头

-(void)parser:didStartElement:namespaceURI:qualifiedName:attributes:

3. 文本节点,得到文本节点里存储的信息数据。 节点中的数据<video>XXXX</video>

- (void)parser:foundCharacters:

4. 结束某个节点  如</video>开头

- (void)parser:didEndElement:namespaceURI:qualifiedName:

注意:在解析过程中,2、3、4三个方法会不停的重复执行,直到遍历完成为止

5.解析XML文档结束

- (void)parserDidEndDocument:

6.解析出错

-( void)parser:parseErrorOccurred:

注意: 从 网络上加装数据是 不能用懒加载的.

XML文件格式如下:

<?xml version="1.0" encoding="utf-8"?>
<videos>
	<video videoId="1">
		<name>苍老师1</name>
		<length>320</length>
		<videoURL>/苍老师1.mp4</videoURL>
		<imageURL>/苍老师1.png</imageURL>
		<desc>学iOS找苍老师1</desc>
		<teacher>苍老师111</teacher>
	</video>

	<video videoId="2">
		<name>苍老师2</name>
		<length>2708</length>
		<videoURL>/苍老师2.mp4</videoURL>
		<imageURL>/苍老师2.png</imageURL>
		<desc>学iOS找苍老师2</desc>
		<teacher>苍老师222</teacher>
	</video>
</videos>      

解析代码如下: ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79

- (

void

)loadData

{

// 1. url确定资源

NSURL *url = [NSURL URLWithString:@

"http://localhost/videos.xml"

];

// 2. request建立请求

NSURLRequest *request = [NSURLRequest requestWithURL:url];

// 3. 发送异步请求,新建数据处理队列,待数据处理完成后,再更新UI

[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {

// 1> 实例化XML解析器

NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data];

// 2> 设置解析器的代理

parser.delegate = self;

// 3> 开始解析

[parser parse];

}];

}

#pragma mark - XML解析代理方法

// 1. 开始解析文档

- (

void

)parserDidStartDocument:(NSXMLParser *)parser

{

// 为了避免重复刷新数据,可以清空数组

[self.videoList removeAllObjects];

}

// 2,3,4三个方法会循环被调用

// 2. 开始一个元素(节点)<xxx>

- (

void

)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict

{

if

([elementName isEqualToString:@

"video"

]) {

// 创建新的video对象

self.currentVideo = [[Video alloc] init];

// 使用KVC赋值

[self.currentVideo setValue:attributeDict[@

"videoId"

] forKeyPath:@

"videoId"

];

}

// 在开始第3个方法前,清空字符串内容

[self.elementM setString:@

""

];

}

// 3. 发现字符(节点中间内容)

- (

void

)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string

{

[self.elementM appendString:string];

}

// 4. 结束节点</xxx>

- (

void

)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName

{

if

([elementName isEqualToString:@

"video"

]) {

// 将当前正在解析的节点添加到数组

[self.videoList addObject:self.currentVideo];

}

else

if

(![elementName isEqualToString:@

"videos"

]) {

[self.currentVideo setValue:self.elementM forKeyPath:elementName];

}

}

// 5. 结束文档解析

- (

void

)parserDidEndDocument:(NSXMLParser *)parser

{

NSLog(@

"结束文档解析 %@"

, self.videoList);

NSLog(@

"%@"

, [NSThread currentThread]);

dispatch_async(dispatch_get_main_queue(), ^{

//UI线程中刷新UI......

});

}

// 6. 在处理网络数据时,千万不要忘记出错处理

- (

void

)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError

{

NSLog(@

"错误 %@"

, parseError);

}

四、JSON解析 解析出来的数据需要进行反序列化,方法如下: [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];

JSON解析方便、且轻量级,特别对于手机端,节省流量,快。 JSON格式数据如下: ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

[

{

"videoId"

:

"1"

,

"name"

:

"苍老师1"

,

"length"

:

"320"

,

"videoURL"

:

"\/苍老师1.mp4"

,

"imageURL"

:

"\/苍老师1.png"

,

"desc"

:

"学iOS找苍老师1"

,

"teacher"

:

"苍老师111"

},

{

"videoId"

:

"2"

,

"name"

:

"苍老师2"

,

"length"

:

"2708"

,

"videoURL"

:

"\/苍老师2.mp4"

,

"imageURL"

:

"\/苍老师2.png"

,

"desc"

:

"学iOS找苍老师2"

,

"teacher"

:

"苍老师222"

}

]

解析代码如下: ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21

- (

void

)loadData

{

// 1. url

NSURL *url = [NSURL URLWithString:@

"http://localhost/videos.json"

];

// 2. request

NSURLRequest *request = [NSURLRequest requestWithURL:url];

// 3. 发送异步请求

[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {

// data是一个json数据

// 对data进行反序列化,解析

NSArray *array = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];

// 刷新数据,更新UI

dispatch_async(dispatch_get_main_queue(), ^{

//在主线程中更新UI......

});

}];

}