网络编程—数据解析(XML)

文艺求关注.png
  • <h5>XML</h5>
    • <b>什么是XML</b>
      全称是Extensible Markup Language,译作“可扩展标记语言”
      跟JSON一样,也是常用的一种用于交互的数据格式
      一般也叫XML文档(XML Decument)
    • <b>XML举例</b>
      <videos>
              <video  name="小黄人  第01部"  length="30"/>
              <video  name="小黄人  第02部"  length="19"/>
              <video  name="小黄人  第03部"  length="33"/>
      </videos>
      
    • <b>XML语法</b>
      一个常见的XML文档一般由以下部分组成
      • 文档声明
      • 元素(Element)
      • 属性(Attribute)

  • <b>XML语法 — 文档声明</b>
    在XML文档的最前面,必须编写一个文档声明,用来声明XML文档的类型

    • 最简单的声明
    <?xml  version="1.0"?>
    
    • 用encoding属性说明文档的字符编码
    <?xml  version="1.0"  encoding="HTF-8"?>
    
  • <b>XML语法 — 元素(Element)</b>
    一个元素包括了开始标签和结束标签

    • 拥有内容的元素标签:<video>小黄人</video>
    • 没有内容的元素:<video></video>
    • 没有内容的元素简写:<video/>

    一个元素可以嵌套若干个子元素(不能出现交叉嵌套)

    <videos>
            <video>
                    <name>小黄人  第01部</name>
                    <length>30</length>
            </video>
    </videos>
    

规范的XML文档最多只有1个根元素,其他元素都是根元素的子孙元素

<b>* XML语法 — 元素的注意点</b>
XML中的所有空格和换行,都会被当作具体内容处理
下面的两个元素的内容是不一样的

  • 第一个
<video>小黄人</video>
  • 第二个
<video>
        小黄人  
</video>
  • <b>XML语法 — 属性(Attribute)</b>
    一个元素可以拥有多个属性
    <video name="小黄人 第01部" length="30"/>

    • video元素拥有name和length两个属性
    • 属性值必须用双引号 " " 或者单引号 ' ' 括住

    实际上,属性表示的信息也可以用字元素来表示,比如

<video>
        <name>小黄人  第01部</name>
        <length>30</length>
</video>

  • <h5>XML解析</h5>
  • 想要从XML中提取有用的信息,必须得学会解析XML
    • 提取name元素里 main的内容
      <name>小黄人 第01部</name>
    • 提取video元素中name和length属性的值
      <video name="小黄人 第01部" length=“30”/>
    • XML的解析方式有2种
      • DOM:一次性将整个XML文档加载进内存,比较适合解析小文件
      • SAX:从根元素开始,按顺序一个元素一个元素往下解析,比较适合解析大文件

<h5>iOS中的XML解析</h5>

  • 在iOS中,解析XML的手段有很多
    • 苹果原生
      • NSXMLParser:SAX方式解析,使用简单
    • 第三方框架
      • libxml2:纯C语言,默认包含在iOS SDK中,同时支持DOMSAX方式解析
      • GDataXML:DOM方式解析,由Google开发,基于libxml2
  • XML解析方式的选择建议
    • 大文件:NSXMLParser、libxml2
    • 小文件:GDataXML、NSXMLParser、libxml2

<h5>XML在代码中使用</h5>
使用NSXMLParser(苹果原生)解析XML(SAX解析)

- (void)useXMLAnalysisData {

    // 01.确定请求路径
    NSURL *url = [NSURL URLWithString:@""];
    
    // 02.创建请求对象
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
    
    // 03.发送请求
    [NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) {
        // 04.XML解析数据
        // 4.1 创建XML解析器
        NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data];
        
        // 4.2 设置代理,本身是阻塞的
        parser.delegate = self;  //遵守协议<NSXMLParserDelegate>
        
        // 4.3 开始解析
        [parser parse];
    }];
}
#pragma mark - NSXMLParserDelegate
// 当扫描到文档的时候开始调用(开始解析)
- (void)parserDidStartDocument:(NSXMLParser *)parser {

}
/**
 当扫描到元素的开始时调用(attributeDict存放着元素的属性)重复调用

 @param parser 解析器
 @param elementName 元素
 @param namespaceURI 命名地址
 @param qName 有效名
 @param attributeDict 属性字典
 */
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary<NSString *,NSString *> *)attributeDict {

    NSLog(@"开始解析--- %@ -------- %@ ----", elementName, attributeDict);
    
    // 过滤根元素
    if ([elementName isEqualToString:@""]) {
        return;
    }
    
    //字典转模型
    [self.videos addObject:[VtcVodeoModel mj_objectWithKeyValues:attributeDict]];
}
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName {

    NSLog(@"结束解析--- %@ ---", elementName);
}
// 当扫描到文档的结束时调用(解析完毕)
- (void)parserDidEndDocument:(NSXMLParser *)parser {

    NSLog(@"%s", __func__);
}
关注一下又不会怀孕.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,194评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,058评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,780评论 0 346
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,388评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,430评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,764评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,907评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,679评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,122评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,459评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,605评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,270评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,867评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,734评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,961评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,297评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,472评论 2 348

推荐阅读更多精彩内容

  • JSON JSON和XML都是需要解析的 JSON是一种轻量级的数据格式,一般用于数据交互服务器返回给客户端的数据...
    JonesCxy阅读 1,847评论 2 10
  • 一、什么是XML 全称是ExtensibleMarkupLanguage,译作“可扩展标记语言” 跟JSON一样,...
    小胖子2号阅读 1,022评论 0 2
  • 解析的基本概念 解析: 从事先规定好的格式中提取数据 解析的前提: 提前约定好格式,数据提供方按照格式提供数据,数...
    云之君兮鹏阅读 1,842评论 4 28
  • JSON 和 XML 一、JSON 1.什么是JSON JSON是一种轻量级的数据格式,一般用于数据交互服务器返回...
    妳是我的天使阅读 349评论 0 3
  • JSON 什么是JSON JSON是一种轻量级的数据格式,一般用于数据交互. 服务器返回给客户端的数据,一般都是J...
    coma阅读 268评论 0 1