zoukankan      html  css  js  c++  java
  • Expat Parser解析xml文件

    Expat 解析器是基于事件的解析器。

    基于事件的解析器集中在 XML 文档的内容,而不是它们的结构。正因为如此,基于事件的解析器能够比基于树的解析器更快地访问数据。

    请看下面的 XML 片段:

    <from>Jani</from>

    基于事件的解析器把上面的 XML 报告为一连串的三个事件:

    • 开始元素:from

    • 开始 CDATA 部分,值:Jani

    • 关闭元素:from

    Expat 是不检查有效性的解析器,忽略任何 DTD。

    作为一款基于事件、非验证的 XML 解析器,Expat 快速且轻巧,十分适合 PHP 的 Web 应用程序。

    注释:XML 文档必须形式良好,否则 Expat 会生成错误。

    XML文档:

    <?xml version="1.0" encoding="utf-8"?>
    <note>
    <to>老爸</to>
    <from>儿子</from>
    <heading>问候</heading>
    <body>最近身体好吗,天气变冷,记得多穿衣服</body>

    <to>老妈</to>
    <from>儿子</from>
    <heading>问候</heading>
    <body>最近身体好吗,天气变冷,记得多穿衣服</body>
    </note>

    PHP文件:

    <?php
    $parser=xml_parser_create();

    function start($parser,$element_name,$element_attrs)
    {
    switch($element_name)
    {
    case "NOTE":
    echo "-- Note --<br>";
    break;
    case "TO":
    echo "To: ";
    break;
    case "FROM":
    echo "From: ";
    break;
    case "HEADING":
    echo "Heading: ";
    break;
    case "BODY":
    echo "Message: ";
    }
    }

    function stop($parser,$element_name)
    {
    echo "<br>";
    }

    function char($parser,$data)
    {
    echo $data;
    }

    xml_set_element_handler($parser,"start","stop");
    xml_set_character_data_handler($parser,"char");

    $fp=fopen("test.xml","r");

    while ($data=fread($fp,4096))
    {
    xml_parse($parser,$data,feof($fp)) or 
    die (sprintf("XML Error: %s at line %d", 
    xml_error_string(xml_get_error_code($parser)),
    xml_get_current_line_number($parser)));
    }

    xml_parser_free($parser);
    ?>

    解析原理:

      1. 通过 xml_parser_create() 函数初始化 XML 解析器

      2. 创建配合不同事件处理程序的的函数

      3. 添加 xml_set_element_handler() 函数来定义,当解析器遇到开始和结束标签时执行哪个函数

      4. 添加 xml_set_character_data_handler() 函数来定义,当解析器遇到字符数据时执行哪个函数

      5. 通过 xml_parse() 函数来解析文件 "note.xml"

      6. 错误处理,添加 xml_error_string() 函数把 XML 错误转换为文本说明

      7. 调用 xml_parser_free() 函数来释放分配给 xml_parser_create() 函数的内存

  • 相关阅读:
    前台传入的application/json;charset=UTF-8格式的数据,java后端从request中获取json数据
    vue-element-admin实战 | 第二篇: 最小改动接入后台实现根据权限动态加载菜单
    vue-element-admin
    进程间通信的几种方式以及线程间通信的几种方式
    vue调用api接口解决跨域问题
    C#多态性(函数重载)
    VirtualBox中安装CentOS7后无法上网的解决方案
    C#继承
    android通过url下载文件
    python的数据爬取
  • 原文地址:https://www.cnblogs.com/-simon/p/5887502.html
Copyright © 2011-2022 走看看