首頁 > php教程 > php手册 > 主體

PHP如何读取xml文件?php读取xml文档例子

WBOY
發布: 2016-05-25 16:42:15
原創
1609 人瀏覽過

PHP如何读取xml文件?有不少朋友不知道这个问题,其实php对于xml文档是有专门的函数来操作了,下面我们就来举几个php读取xml例子希望能给各位带来帮助.

一,什么是xml,xml有什么用途

XML(Extensible Markup Language)即可扩展标记语言,它与HTML一样,都是SGML(Standard Generalized Markup Language,标准通用标记语言),Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,扩展标记语言XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用.

XML的用途很多,可以用来存储数据,可以用来做数据交换,为很多种应用软件提示数据等等.

二,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(&#39;person.xml&#39;); //读取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\n";
}
?>
登入後複製

2)simplexml读取xml,代码如下:

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

如果你使用 curl 获取的 xml data

$xml = simplexml_load_string($data);

$data['tk'] = json_decode(json_encode($xml),TRUE);

如果是直接获取 URL 数据的话

$xml = simplexml_load_file($data);

$data['tk'] = json_decode(json_encode($xml),TRUE);

先把 simplexml 对象转换成 json,再将 json 转换成数组.

3)用php正则表达式来记取数据,代码如下:

<?php
$xml = "";
$f = fopen(&#39;person.xml&#39;, &#39;r&#39;);
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(&#39;person.xml&#39;); //读取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文件出来了.

举个例子解释一下,代码如下:

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


文章地址:

转载随意^^请带上本文地址!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板