zoukankan      html  css  js  c++  java
  • 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://blog.csdn.net/jerehedu/ 
    本文版权归烟台杰瑞教育科技有限公司和CSDN共同拥有。欢迎转载。但未经作者允许必须保留此段声明。且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
     
  • 相关阅读:
    Enterprise Library 4.1 Data Access Block 快速使用图文笔记
    敏捷开发(名字起得很帅,很忽悠人)原则 括号里面加了自己的理解笔记
    与弟弟谈话的摘要
    练习:选头像控件
    [转]保护你的flash(as3)程序基于socket方式传送swf文件
    Silverlight 又多了一套skin
    Silverlight制作逐帧动画
    Silverlight Spy 2 源代码查看器
    跨平台开发silverlight
    Silverlight 2 搜索照片 Live
  • 原文地址:https://www.cnblogs.com/mthoutai/p/6985729.html
Copyright © 2011-2022 走看看