【iOS】Plist-XML-JSON資料解析,iosplist-xml-json

來源:互聯網
上載者:User

【iOS】Plist-XML-JSON資料解析,iosplist-xml-json

網路上傳輸資料通用的有XML,JSON等,iOS中也可以用Plist。

要進行資料轉送,就要首先進行序列化:

1.序列化. 對象轉換成二進位流.(這個一句話就行)2.還原序列化.二進位流轉換為對象等. (關鍵要弄清楚這個)
JSON:(和XML一樣都是用來傳資料的)輕量級的資料交換格式,正在逐步取代XML.XML:結構性的標記語言,易讀.但資料量大. Plist偶爾用著玩玩:Mac、iOS中用的多一種格式。
一、應用情境1、XML的應用情境:XMPP——即時通訊,KissXMLRSS目前還有少量的企業在使用開源的WebServices,例如天氣預報等如果設計好XML的介面,XML的解析並不會太複雜
2、JSON的應用情境:(資料量小,輕量級)移動開發中絕大多數還是使用JSON如果自己開發,或者公司後台介面,最好使用JSON.
二、Plist解析資料定義一個Plist的格式如下:

解析代碼如下:(在非同步線程中進行, 最後得到array)
- (void)loadData{    // 1. url    NSURL *url = [NSURL URLWithString:@"http://localhost/videos.plist"];        // 2. request    // timeoutInterval 如果5.0之內沒有從伺服器返回結果,就認為逾時了    /**     NSURLRequestUseProtocolCachePolicy = 0,            // 使用協議緩衝策略(預設)     NSURLRequestReloadIgnoringLocalCacheData = 1,      // 忽略本機快取資料(斷點續傳時使用)     NSURLRequestReloadIgnoringCacheData = NSURLRequestReloadIgnoringLocalCacheData, == 1          // 以下少用     NSURLRequestReturnCacheDataElseLoad = 2,           // 如果有緩衝,就返回快取資料,否則載入     NSURLRequestReturnCacheDataDontLoad = 3,           // 死活不載入遠程伺服器資料,如果使用者沒有網路連接時可以使用          // 以下沒有實現     NSURLRequestReloadIgnoringLocalAndRemoteCacheData = 4, // 沒有實現     NSURLRequestReloadRevalidatingCacheData = 5, // 沒有實現     */    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>
解析代碼如下
/** 載入資料 */- (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個方法前,清Null 字元串內容    [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格式資料如下:
[{"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"}]
解析代碼如下:
- (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......        });    }];}


轉載請註明出處:http://blog.csdn.net/xn4545945  




ios開發的各位,教一下 plist檔案解析

plist檔案就相當於程式裡面的dictionay裡面可以層層嵌套dictionary或者array。解析就是讀取內容放進dictionary就可以了。
 
ios用asihttprequest下來的xml資料怎解析

自己用最基礎的找關鍵字解析或者是用一些 XML的解析架構
像 sdk 內建的 NSXMLParser
或者是 google 的 NSData

NSXMLParse 直接文檔裡搜,有範例程式碼和文檔協助
NSData google或者baidu搜,網上很多例子
 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.