PHP操作XML文件学习笔记
XML文件属于标签语言,可以通过自定义标签存储数据,其主要作用也是作为存储数据。
对于XML的操作包括遍历,生成,修改,删除等其他类似的操作。PHP对于XML的操作方式很多,这次学习的是通过DOMDocument进行操作,其他的操作方法可以参考
http://www.oschina.net/code/snippet_110138_4727
1.对XML文件的遍历
通过DOMDocument对于XML文件的操作的方法:首先要实例化一个DOMDocument类的对象,然后引入要操作的XML文件。即:
$doc = new DOMDocument();
$doc->load("test.xml");
对于XML的遍历是通过获取XML文件中的标签名称,从而获取标签中的内容的,例如XML文件内容为:
<?xml version="1.0" encoding="utf-8" ?>
<school>
<student>
<name>张三</name>
<sex>男</sex>
<age>19</age>
</student>
<student>
<name>李四</name>
<sex>女</sex>
<age>18</age>
</student>
<student>
<name>王五</name>
<sex>男</sex>
<age>19</age>
</student>
</school>
现在通过PHP遍历出每个student的信息,通过 getElementsByTagName() 方法获取到指定名称的标签并存为数组,然后遍历信息:
$content = $doc->getElementsByTagName("student");
foreach($content as $value){
echo $value->nodeValue."<br />";
}
注意:在遍历XML文件的时候,要注意的一个问题就是编码的问题,如果xml文件的encoding为"utf-8",那么xml文件的文件编码也必须是utf-8,可以通过文本编辑器将文件另存为和xml的encoding相同的文件编码即可。否则在遍历的时候会报错或者出现乱码。
2.生成XML文件
在生成XML文件的时候,是通过DOMDocument类中的方法来创建各个节点和节点内容的。我通过查询数据库,并将数据库中的信息生成XML文件方法如下:
include "database.php"; //导入连接数据库文件
$query = mysql_query("SELECT * FROM test"); //操作xml准备
$doc = new DOMDocument("1.0","utf-8"); //通过createElement方法为xml文件创建节点
//创建根节点
$school= $doc->createElement("school");
//通过appendChild方法将节点或属性添加到指定的标签下
//将根节点添加到xml文件中
$doc->appendChild($school); //创建student节点
$student= $doc->createElement("student");
//将student节点添加到school节点下
$school->appendChild($student); $nameinfo = array(); //对应xml文件中name标签下的内容
$sexinfo = array(); //对应xml文件中sex标签下的内容
$ageinfo = array(); //对应xml文件中age标签下的内容
$idinfo = array(); //对应xml文件中属性id的值
$i = 0; //控制变量i while($row=mysql_fetch_array($query)){
//通过createTextNode方法为标签节点赋值或者为属性赋值
//查询数据库信息并赋值给相应的数组
$nameinfo[$i] = $doc->createTextNode($row["name"]);
$sexinfo[$i] = $doc->createTextNode($row["sex"]);
$ageinfo[$i] = $doc->createTextNode($row["age"]);
$idinfo[$i] = $doc->createTextNode($i);
$i++;
} for($i=0;$i<count($nameinfo);$i++){
$name = $doc->createElement("name");
$sex = $doc->createElement("sex");
$age = $doc->createElement("age");
//通过createAttribute为节点标签创建属性
$id = $doc->createAttribute("id"); //将name、sex、age标签添加到student标签下,并且为student标签赋属性id
$student->appendChild($name);
$student->appendChild($sex);
$student->appendChild($age);
$student->appendChild($id); //将从数据库中取出的值添加到对应的标签下
$name->appendChild($nameinfo[$i]);
$sex->appendChild($sexinfo[$i]);
$age->appendChild($ageinfo[$i]);
$id->appendChild($idinfo[$i]);
} //通过save方法将生成的xml文件保存
$doc->save("test.xml");
注意:在生成XML文件的时候同样应该注意编码问题,除了XML文件编码和XML指定编码应当一致以外,在连接数据库的时候还应该注意XML指定的编码应该和数据库的编码一致,另外在生成XML文件的时候应当特别注意各级标签的从属关系。
3.XML文件的修改和删除
在对XML文件中的数据进行修改和删除的时候,首先还是应该要将操作的XML引入,方法同遍历时一样。在修改或者删除时通过标签的属性及其值进行定位,方法如下:
$doc= new DOMDocument();
$doc->load("test.xml"); //通过getElementsByTagName方法获取到所有标签为student的标签内容,并存为数组$students
$students = $doc->getElementsByTagName("student"); //遍历$students,将每个student的信息存为$student
foreach($students as $student){
//通过getAttribute获取指定属性的值
//将id为2的student标签的name修改为kenticny
if($student->getAttribute("id")==2){
$content = $doc->getElementsByTagName("name")->item(0)->nodeValue = "Kenticny";
}
//将id为1的student标签内容删除
if($student->getAttribute("id")==1){
//通过removeChild方法移除指定的标签内容
//在移除标签内容时候要通过被移除标签的父标签进行操作,获取父标签通过parentNode进行获取
$student->parentNode->removeChild($student);
} }
//保存修改的XML文件
$doc->save("test.xml");
注意:在对XML进行修改和删除的时候,需要注意的是,修改和删除都是要通过指定标签的属性进行定位操作,然后在删除时候注意应当使用被删除标签的父标签进行删除操作。
以上是我对于PHP通过DOMDocument方法操作XML文件的学习笔记。欢迎转载----转载请注明出处 BY 津志伊恋 2012年4月24日
PHP操作XML文件学习笔记的更多相关文章
- WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)
WebAPI调用笔记 前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...
- 利用XmlDocument操作XML文件
利用XmlDocument可以方便的操作XML文件. .操作XML文件基本方法 ()添加对System.Xml的引用,并使用using语句添加引用: ()假设要读取的XML文件如下: <?xml ...
- Qt之QDomDocument操作xml文件-模拟ini文件存储
一.背景 不得不说Qt是一个很强大的类库,不管是做项目还是做产品,Qt自身封装的东西就已经非常全面了,我们今天的这篇文章就是模拟了Qt读写ini文件的一个操作,当然是由于一些外力原因,我们决定自己来完 ...
- JAVA中通过Jaxp操作XML文件基础
Java中有多种方式操作XML文件,目前讲一讲以SUN公司提供的DocumentBuilderFactory工厂类对象操作XML. 使用XML基本操作就是需要CRUD(增删改查),那么首先通过一个查询 ...
- Asp.Net 操作XML文件的增删改查 利用GridView
不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...
- Java操作XML文件 dom4j 篇
在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它系统的数据交互.今天就来讲一下Java 中使用dom4j来操作XML文件. 我们需要引入的包: //文件包 import java.io. ...
- python第三方库——xlrd和xlwt操作Excel文件学习
python第三方库——xlrd和xlwt操作Excel文件学习 1安装: C:\Users\Lenovo>pip install xlwtCollecting xlwt Downloadin ...
- C#操作xml文件:使用XmlDocument 实现读取和写入
XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内 ...
- C#基础知识---Linq操作XML文件
概述 Linq也就是Language Integrated Query的缩写,即语言集成查询,是微软在.Net 3.5中提出的一项新技术. Linq主要包含4个组件---Linq to Objects ...
随机推荐
- ZOJ Problem Set - 3829Known Notation(贪心)
ZOJ Problem Set - 3829Known Notation(贪心) 题目链接 题目大意:给你一个后缀表达式(仅仅有数字和符号),可是这个后缀表达式的空格不幸丢失,如今给你一个这种后缀表达 ...
- java实现xml文件CRUD
java删除xml多个节点: 方案1.你直接改动了nodeList.这一般在做循环时是不同意直接这么做的. 你能够尝试在遍历一个list时,在循环体同一时候删除list里的内容,你会得到一个异常.建议 ...
- 【Linux&Unix--open/close/write/read系统调用】
个人学习整理.如有不足之处,请不吝不吝赐教. 转载请注明:@CSU-Max 系列博文: Linux&Unix学习第一弹 -- 文件描写叙述符与权限 Linux&Unix学习 ...
- jrtplib使用注意事项
一.说明 RTP 现在的问题是要解决的流媒体的实时传输的问题的最佳方法.和JRTPLIB 是一个用C++语言实现的RTP库.包含UDP通讯.刚使用JRTPLIB,对JRTPLIB的理解还不够深,当做使 ...
- Oracle 11g client安装和配置。
数据库和client在不同的机器. 安装前的准备.在安装过程中Oracle数据库server导航到下面的文件夹. 将listener.ora和tnsnames.ora中的host中的localhost ...
- 快速排序java
快速排序(Quicksort)是对冒泡排序的一种改进.它是先在数组中找到一个关键数,第一趟排序将比关键数小的放在它的左边,比关键数大的放在它的右边.当第一趟排序结束后,再依次递归将左边和右边的进行排序 ...
- Java自定义比较器Comparator
1.数字排序 奇数在前,偶数在后.奇数降序,偶数升序.输入:"0,1,2,3,4,5,6,7,8,9" 输出:"9,7,5,3,1,0,2,4,6,8&q ...
- 【原创】leetCodeOj --- Find Minimum in Rotated Sorted Array II 解题报告
题目地址: https://oj.leetcode.com/problems/find-minimum-in-rotated-sorted-array-ii/ 题目内容: Suppose a sort ...
- Oracle DG故障诊断一则:alter database recover to logical standby new_logical_dbname卡住
我们在基于物理standby的基础上搭建逻辑备库过程过程中,在运行: alter database recover to logical standby READDB; 卡住不动,而且alert也没有 ...
- 编译hibernate源代码
1)安装gradle,gradle是一个类似maven的构建工具 2)安装gitclient. 从网址 https://github.com/hibernate/hibernate-orm 上clon ...