1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > PHP如何读取xml文件?php读取xml文档例子

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

时间:2023-11-23 08:45:15

相关推荐

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

php教程|php手册

php读取xml文件,php读取xml文档

php教程-php手册

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

借还系统 源码,vscode好用主题,sql ubuntu,tomcat项目报错,远程连接sqlite3,网易云音乐Discuz插件,前端框架师在上海工资多少,网页图片爬虫快捷指令大全,php安装curl扩展,byeong-seo kim,美食网站源代码,微信网页版 图片 htm,中国金融培训在线网站模板下载lzw

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

网站电脑直播源码,ubuntu里的vnc,python爬虫收费项目,excel php 导入,seo的英文lzw

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

433源码,vscode退回到上一步,ubuntu设置man,tomcat 项目地址映射,爬虫宠物 白蛇,php 程序员 考试,贵州seo优化搜索排名哪家强lzw

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

二,php读取xml的方法

xml源文件,代码如下:

<?xml version="1.0 encoding="UTF-8" 张映 男 28 tank 男 28

1)DOMDocument读取xml,代码如下:

load(person.xml); //读取xml文件$humans = $doc->getElementsByTagName("humans"); //取得humans标签的对象数组foreach ($humans as $human) { $names = $human->getElementsByTagName("name"); //取得name的标签的对象数组 $name = $names->item(0)->nodeValue; //取得node中的值,如$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,代码如下:

name . "-" . $tmp->sex . "-" . $tmp->old . "

";}?>

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

";}?>4)xmlreader来读取xml数据,代码如下: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 . "

"; } $i++; }}?>

三,小结

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

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

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

文章地址:

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。