• IOS中的XML解析之DOM和SAX


    一、介绍

      dom是w3c指定的一套规范标准,核心是按树形结构处理数据,dom解析器读入xml文件并在内存中建立一个结构一模一样的“树”,这树各节点和xml各标记对应,通过操纵此“树”来处理xml中的文件。xml文件很大时,建立的“树”也会大,所以会大量占用内存。
      sax解析器核心是事件处理机制。例如解析器发现一个标记的开始标记时,将所发现的数据会封装为一个标记开始事件,并把这个报告给事件处理器,事件处理器再调用方法(startElement)处理发现的数据。下面我们尝试一下SAX和DOM解析:

      XML格式如下:

    二、SAX:

      1、我们用SAX解析的时候用的是苹果自带的NSXMLParser,首先初始化一个解析器,通过设置代理开始解析,代码如下:

    //初始化路径
      NSString * path=[[NSBundle mainBundle] pathForResource:@"Test.xml" ofType:nil];
      NSData * data=[NSData dataWithContentsOfFile:path];
      //初始化解析器
     NSXMLParser * parser=[[NSXMLParser alloc] initWithData:data];
    //设置代理
     parser.delegate=self;
    //开始解析
     [parser parse];

      2、通过代理方法开始解析,由于sax方式是事件驱动,因此解析是按照顺序解析,如果想获取标签的数据我们需要监控每个步骤的解析情况,因此系统提供了代理方法给我们,下面便是常用代理方法:

    //开始加载文档
    - (void)parserDidStartDocument:(NSXMLParser *)parser{}
    
    //结束加载文档
    - (void)parserDidEndDocument:(NSXMLParser *)parser{
    
    }
    //开始解析标签
    - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict{
    }
    //标签解析结束
    - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName{
    }
    //读取标签之间的文本
    - (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string{
        content=string;
    }

      3、XM有两种存值方式,一个是属性,一个是标签之间的文本。如果我们想获取属性需要在代理方法中获取,如图:

     

    如果是获取标签之间的文本需要采用代理方法如图:

     

    总结:通过给定代理方法的结合我们便可以轻松的获取XML的内容

    三、DOM

    1、我们用DOM解析的时候用的是第三方框架GDataXMLNode,该框架为动态库。我们需要引入如下:

      同时需要引入第三方支持框架:

      DOM解析相对于SAX稍微简单一些,DOM 首先将整个文件全部放入内存。然后在内存中以二叉树的形式获取里面的元素内容。

      涉及到的主要类:

    GDataXMLDocument //整个文档

    GDataXMLElement  //节点对象

    GDataXMLNode     //属性节点对象

      我们可以用以下方法解析数据

    //初始化
     //将文件加入到内存
    GDataXMLDocument * document=[[GDataXMLDocument alloc] initWithData:data options:0 error:nil];
      //获取根元素
        GDataXMLElement  * root=document.rootElement;
    //获取所有该名称的子节点
    -(NSArray *)elementsForName:(NSString *)name;
    //根据名称获取属性值
    -(GDataXMLNode*)attributeForName:(NSString *)name;

      这样我们便可以轻松解析并且获取XMl的值了,如图:

      想要了解更多内容的小伙伴,可以点击查看源码,亲自运行测试。

      疑问咨询或技术交流,请加入官方QQ群:JRedu技术交流 (452379712)

    作者:杰瑞教育
    出处:http://www.cnblogs.com/jerehedu/ 
    本文版权归烟台杰瑞教育科技有限公司和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
     
  • 相关阅读:
    万字攻略,详解腾讯面试
    百度广告产品系统级测试技术演进
    TAR部署MYSQL(1)
    RPM部署MYSQL
    大数据学习之Linux(3)
    大数据学习之linux(2)
    大数据学习之linux(1)
    pycharm安装与破解
    Dijkstra—校园景点游览问题
    哈夫曼编译码器
  • 原文地址:https://www.cnblogs.com/jerehedu/p/4599582.html
Copyright © 2020-2023  润新知