• 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的值了,如图:

  • 相关阅读:
    案例19-页面使用ajax显示类别菜单
    案例18-首页最新商品和热门商品显示
    案例17-validate自定义校验规则校验验证码是否输入正确
    案例16-validate自定义校验规则校验用户名是否存在
    案例15-基本的表单校验使用validate
    测开之路六十九:监控平台之视图层
    测开之路六十八:监控平台之监控逻辑和处理逻辑
    测开之路六十七:监控平台之附加功能准备
    测开之路六十六:UI测试平台之处理逻辑和蓝图添加到程序入口
    测开之路六十五:UI测试平台之js
  • 原文地址:https://www.cnblogs.com/yunxinxi/p/4605048.html
Copyright © 2020-2023  润新知