JSON和XML數(shù)據(jù)解析

JSON

1.JSON是一種輕量級(jí)的數(shù)據(jù)格式,一般都是用于數(shù)據(jù)交互
2.服務(wù)器返回給客戶端的數(shù)據(jù),一般都是JSON格式或者XML格式(文件下載除外)
3.JSON的格式很像OC中的字典和數(shù)組
{"name" : ["jim","jack","rose"] ,"age" : 10}
標(biāo)準(zhǔn)的JSON格式注意點(diǎn):key必須用雙引號(hào)
4.想要從JSON中挖掘數(shù)據(jù),就得對(duì)JSON進(jìn)行解析
JSON--->OC數(shù)據(jù)類型


Snip20150930_17.png

5.對(duì)于JSON數(shù)據(jù)的解析,我們推薦用蘋果原生:NSJSONSerialization(性能最好)

常用方法有:

JSON--->OC對(duì)象[我們稱之為JSON數(shù)據(jù)序列化--一般轉(zhuǎn)化成OC中的字典,或者數(shù)組. 具體根據(jù)傳入的JSON數(shù)劇算]
+ (id)JSONObjectWithData:() options:(NSJSONReadingOptions)opt error:(NSError **)error

OC對(duì)象--->JSON數(shù)據(jù)[我們稱之為JSON數(shù)據(jù)的反序列化--也就是將數(shù)據(jù)轉(zhuǎn)換為JSON數(shù)據(jù)]
+ (NSData *)dataWithJSONObject:(id)obj options:(NSJSONWritingOptions)opt error:(NSError *)error

序列化
 NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON"]; 
    NSURLRequest *request = [NSURLRequest requestWithURL:url]; 
    [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
        
        // 將相應(yīng)數(shù)據(jù)data ,轉(zhuǎn)換成json數(shù)據(jù)。
        // 第一個(gè)參數(shù): 需要轉(zhuǎn)換的data
        // 第二個(gè)參數(shù):關(guān)于 數(shù)據(jù)顯示后的一些配置
        /*
         NSJSONReadingMutableContainers = (1UL << 0),解析出來(lái)的數(shù)組和字典是可變的(可變?nèi)萜鳎?         NSJSONReadingMutableLeaves = (1UL << 1),    解析出來(lái)的字符串是可變的(ios7 以前用的)
         NSJSONReadingAllowFragments = (1UL << 2)    被解析的數(shù)據(jù) 既不是字典 也不是字符串的時(shí)候
         NSNumber,NSBOOLen NSNULL(對(duì)象,用于占位的),nil(0)
         */
        
        
        NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding ];
      NSData *json = [NSJSONSerialization JSONObjectWithData:data options: NSJSONReadingMutableContainers error:nil];
    
        NSLog(@"%@-----%@",str,json);
    }];

#######反序列化

NSDictionary *dict = @{
                           
                           @"name":@"小明",
                           @"age":@16,
                           @"schools":@[
                                        @{@"小學(xué)":@"123"},
                                        @{@"初中":@"456"},
                                        @{@"大學(xué)":@"789"}
                                      ],
                           };
    // 對(duì)象轉(zhuǎn)換成 json ,
    // 第一個(gè)參數(shù):傳入需要轉(zhuǎn)換的對(duì)象
    // 對(duì)象轉(zhuǎn)換以后的排版方式,沒什么意義
    
     NSData *data = [NSJSONSerialization dataWithJSONObject:dict options:kNilOptions error:nil];
    NSLog(@"%@",[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding]);

為了讓序列化出來(lái)出來(lái)的數(shù)組,在控制臺(tái)的打印清晰明了,于是重寫了[NSDictionary,NSArray加分類, 然而可以直接寫在一個(gè).m文件中, 只是按照分類寫法就行了, 一個(gè)文件中允許有兩個(gè)@implementation ,但是不能嵌入式使用. 重寫的方法在調(diào)用 NSLog時(shí) 會(huì)自動(dòng)調(diào)用, 這個(gè)方法就是為了格式固定的,以及調(diào)試使用] - (NSString *)descriptionWithLocale:(id)locale
- (NSString *)descriptionWithLocale:(id)locale

#import <Foundation/Foundation.h>

@implementation NSDictionary (LXL)

- (NSString *)descriptionWithLocale:(id)locale
{
    // 1.定義字符串保存的拼接結(jié)果。
    NSMutableString *strMut = [NSMutableString string];
    [strMut appendString:@"{\n"];
    
    [self enumerateKeysAndObjectsUsingBlock:^(id key, id obj, BOOL *stop) {
       
        [strMut appendFormat:@"\t%@:%@\n",key,obj];
        
    }];
     [strMut appendString:@"}\n"];
    return strMut;
 
}

@end

@implementation NSArray (LXL)

- (NSString *)descriptionWithLocale:(id)locale
{
    // 1.定義字符串保存的拼接結(jié)果。
    NSMutableString *strMut = [NSMutableString string];
    [strMut appendString:@"(\n"];
    
    [self enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
        [strMut appendFormat:@"%@\n",obj];
    }];
    [strMut appendString:@")\n"];
    return strMut;
}
@end

在項(xiàng)目中一般介紹到的JSON數(shù)據(jù),都是將其轉(zhuǎn)換成模型數(shù)據(jù)進(jìn)行保存, 更有方便的方法,就是將其轉(zhuǎn)換成plist文件保存在文件沙盒中, 方便讀取. (這是關(guān)于文件的持久化的管理)

Snip20151001_1.png

XML

基本介紹

1.全稱:Extension Markup Language : 可擴(kuò)展標(biāo)記語(yǔ)言
2.交互數(shù)據(jù)格式 html語(yǔ)言 DOM標(biāo)簽組成
3.組成部分: 文檔聲明[相當(dāng)于Html中的header], 元素
(Element),屬性(Attribute)

解析方式:

DOM:一次性將整個(gè)XML文檔加載進(jìn)內(nèi)存,比較適合解析小文件
SAX:從根元素開始,按順序一個(gè)元素一個(gè)元素往下解析,比較適合大文件的解析

iOS中的XML解析

解析方式: NSXMLParser(大小),使用方便 ,
三方框架GDataXML(小)

下面來(lái)介紹GDataXML的使用

1.GDataXML基于libxml2庫(kù), 必須導(dǎo)入libxml2庫(kù)(添加依賴庫(kù))
2.因?yàn)镚DataXML是非ARC,所以需要混編 ,混編方法


Snip20151001_2.png

GDataXML中的常用類

1.GDataXMLDocument:帶便整個(gè)XML文檔
2.GDataXMLElement:代表文檔中的每一個(gè)元素
使用attributeForName:方法可以獲取屬性值

 NSString *urlStr = @"http://120.25.226.186:32812/video?type=XML";
    NSURL *url = [NSURL URLWithString:urlStr];
// 設(shè)置請(qǐng)求
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 發(fā)送異步請(qǐng)求,獲取服務(wù)器數(shù)據(jù)
    [NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
        // 將接收到的數(shù)據(jù)轉(zhuǎn)換為 xml文件
         GDataXMLDocument *document = [[GDataXMLDocument alloc]initWithData:data options:kNilOptions error:nil];
        // 獲取文檔中的每一個(gè)元素(外層)
          GDataXMLElement *element = document.rootElement;
        // 打印驗(yàn)證所有元素
        NSLog(@"%@",element);
        // 獲取 元素中的內(nèi)容 (內(nèi)層元素)
        NSArray *elements = [element elementsForName:@"video"];
        for (GDataXMLElement *element in elements) {
     
            VideoModel *model = [[VideoModel alloc]init];
            // 取出每一個(gè)子元素中的屬性, 再給模型賦值保存數(shù)據(jù)
            model.name =  [element attributeForName:@"name"].stringValue;
            model.url = [element attributeForName:@"url"].stringValue;
            model.image = [element attributeForName:@"image"].stringValue;
            model.length = [element attributeForName:@"length"].stringValue.intValue;
            [self.videos addObject:model]; 
            [self.tableView reloadData];
            
        }
    }];
下面來(lái)介紹NSXMLParser的使用

使用步驟

1.傳入XML數(shù)據(jù),創(chuàng)建解析器
NSXMLParser *parser = [[NSXMLParser alloc]initWithData:Data]
2.設(shè)置代理,監(jiān)聽解析過程
parser.delegate = self
3.開始解析
[parser parse]

NSXMLParser采用的是SAX方式解析,特點(diǎn)是事件驅(qū)動(dòng),下面情況都會(huì)通知代理

1.當(dāng)掃描到文檔Document的開始與結(jié)束
2.當(dāng)掃描到元素Element的開始和結(jié)束

NSXMLParserDelegate的代理方法

1.當(dāng)掃描到文檔的開始時(shí)調(diào)用(開始解析)
- (void)parserDidStartDocument:(NSXMLParser *)parser
2.當(dāng)掃描到文檔的結(jié)束時(shí)調(diào)用(解析完畢)
- (void)parserDidEndDocument:(NSXMLParser *)parser
3.當(dāng)掃描到元素開始時(shí)調(diào)用(attributeDict存放著元素的屬性)
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *) nsmespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
4.當(dāng)掃描到元素的結(jié)束時(shí)調(diào)用
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName (NSString *)qName
在實(shí)際應(yīng)用中的使用方法:

// 將解析的每一元素,進(jìn)行轉(zhuǎn)換,存儲(chǔ),可以存儲(chǔ)在plist文件中,也可以保存在模型數(shù)據(jù)中
// 開始解析xml中的每一個(gè)元素,從大到小
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
    
    // 將解析到的字典屬性, 進(jìn)行模型轉(zhuǎn)換
    VideoModel *model = [VideoModel objectWithKeyValues:attributeDict];
    // 將模型添加到模型數(shù)組
    [self.videos addObject:model];
    // 每添加一組,進(jìn)行數(shù)據(jù)更新
    [self.tableView reloadData];


}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容