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 ...
随机推荐
- 【shell文字】mysql每日备份shell文字
每天固定时间使用mysqldump 备份mysql数据. #!/bin/bash #每天早上4点, mysql备份数据 orangleliu #chmod 700 backup.sh #crontab ...
- Android SwipeRefreshLayout 官方下拉刷新控件介绍
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24521483 下面App基本都有下拉刷新的功能,以前基本都使用XListView ...
- Spring+Mybatis+SpringMVC后台与前台分页展示实例(附工程)(转)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文实现了一个后台由Spring+Mybatis+SpringMVC组成,分页采用Pag ...
- js操作string它substr方法
substr 方法 从指定的指定起始位置的长度返回一个子. stringvar.substr(start [, length ]) 參数 stringvar 必选项. 要提取子字符串的字符串文字或 S ...
- 《图书管理系统——java》
/* (程序头部凝视開始) * 程序的版权和版本号声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名: < ...
- poj 2408 Anagram Groups(hash)
id=2408" target="_blank" style="">题目链接:poj 2408 Anagram Groups 题目大意:给定若干 ...
- 玩转Web之easyui(一)-----easy ui datagird 分页
easy ui 中数据表格的分页其实是很简单的,分页是在数据表格可以正常显示数据的基础上进行的,在这里给出servlet的代码,其中selectAll()方法是从数据库中提取所有数据, 分页的一种思路 ...
- Spark 1.0.0版本发布
前言 如今Spark终于迈出了里程碑一步,1.0.0标记的版本号出版物Spark1.0时代.1.0.0版本号不仅增加了非常多新特性.而且提供了更好的API支持.Spark SQL作为一个新的组件增加. ...
- C#多线程编程实例 螺纹与窗口交互
C#多线程编程实例 螺纹与窗口交互 代码: public partial class Form1 : Form { //声明线程数组 Thread[] workThreads = new Thread ...
- Visual Studio 2015 中文企业版及专业版 正式版下载地址 激活秘钥 正版key
Visual Studio 简体中文企业版 2015 (x86 and x64)文件名 cn_visual_studio_enterprise_2015_x86_x64_dvd_6846222.iso ...