zoukankan      html  css  js  c++  java
  • php操作xml的方法

     

     xml源文件

    <?xml version="1.0 encoding="UTF-8"?>
    <humans>
    <zhangying>
    <name>张映</name>
    <sex>男</sex>
    <old>28</old>
    </zhangying>
    <tank>
    <name>tank</name>
    <sex>男</sex>
    <old>28</old>
    </tank>
    </humans>
    

      

      1)DOMDocument读取xml

    <?php 
    $doc = new DOMDocument(); 
    $doc->load('person.xml'); //读取xml文件 
    $humans = $doc->getElementsByTagName( "humans" ); //取得humans标签的对象数组 
    foreach( $humans as $human ) 
    { 
    $names = $human->getElementsByTagName( "name" ); //取得name的标签的对象数组 
    $name = $names->item(0)->nodeValue; //取得node中的值,如<name> </name> 
    $sexs = $human->getElementsByTagName( "sex" ); 
    $sex = $sexs->item(0)->nodeValue; 
    $olds = $human->getElementsByTagName( "old" ); 
    $old = $olds->item(0)->nodeValue; 
    echo "$name - $sex - $old
    "; 
    } 
    ?>
    
     

      2)simplexml读取xml

    <?php 
    $xml_array=simplexml_load_file('person.xml'); //将XML中的数据,读取到数组对象中 
    foreach($xml_array as $tmp){ 
    echo $tmp->name."-".$tmp->sex."-".$tmp->old."<br>"; 
    } 
    ?>

      3)用php正则表达式来记取数据

    <?php 
    $xml = ""; 
    $f = fopen('person.xml', 'r'); 
    while( $data = fread( $f, 4096 ) ) { 
    $xml .= $data; 
    } 
    fclose( $f ); 
    // 上面读取数据 
    preg_match_all( "/<humans>(.*?)</humans>/s", $xml, $humans ); //匹配最外层标签里面的内容 
    foreach( $humans[1] as $k=>$human ) 
    { 
    preg_match_all( "/<name>(.*?)</name>/", $human, $name ); //匹配出名字 
    preg_match_all( "/<sex>(.*?)</sex>/", $human, $sex ); //匹配出性别 
    preg_match_all( "/<old>(.*?)</old>/", $human, $old ); //匹配出年龄 
    } 
    foreach($name[1] as $key=>$val){ 
    echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."<br>" ; 
    } 
    ?>
    
     
    

      

      4)xmlreader来读取xml数据

    <?php 
    $reader = new XMLReader(); 
    $reader->open('person.xml'); //读取xml数据 
    $i=1; 
    while ($reader->read()) { //是否读取 
    if ($reader->nodeType == XMLReader::TEXT) { //判断node类型 
    if($i%3){ 
    echo $reader->value; //取得node的值 
    }else{ 
    echo $reader->value."<br>" ; 
    } 
    $i++; 
    } 
    } 
    ?>
    
     

      三,小结

      读取xml的方法很多,简单举几个。上面四种方法都是可以把标签中的数据读出来,张映.但是他们的测重点不同,前三种方 法的读取xml的function的设计重点,是为了读取标签中的值,相当于jquery中的text()方法,而xmlreader呢他就不太一样,他 的重点不在读取标签中的值,而读取标签的属性,把要传送的数据,都放在属性中(不过我上面写的那个方法还是取标签中的值,因为xml文件已经给定了,我就 不想在搞xml文件出来了)。

      举个例子解释一下,

      <data name=’张映’ sex=’男’ old=’28′></data>

      xmlreader的设计重点是为了读data里面的name sex old的值,而读取的内容就比较麻烦了。他相当于jquery中attr(”);这个东西。

      上面纯属个人看法,请大家指正。希望对大家有帮助。

  • 相关阅读:
    【Linux】linux中很有用的指令(练习)
    【C 标准库】<string.h>
    【Linux网络编程】使用GDB调试程序
    【LINUX网络编程】Makefile文件
    【UNIX网络编程】TCP客户/服务器程序示例
    【UNIX网络编程】基本TCP套接字编程
    pyQt5新手教程 (二)通过jupyter开始你的旅程-编写一个空白窗口
    pyQt5新手教程 (一)通过anaconda安装pyqt包
    如何把没用的tplink4C68路由器连起来
    xcode10升级之后开始安装cocoapods
  • 原文地址:https://www.cnblogs.com/jthb/p/4067615.html
Copyright © 2011-2022 走看看