Heim >php教程 >php手册 >PHP如何读取xml文件?php读取xml文档例子

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

WBOY
WBOYOriginal
2016-05-25 16:42:151625Durchsuche

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('');这个东西.                                        


文章地址:

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn