PHP原生DOM对象操作XML'代码'
对于操作XML类型文件,PHP内置有一套DOM对象可以进行处理。对XML的操作,从创建、添加到修改、删除都可以使用DOM对象中的函数来进行。
创建
创建一个新的XML文件,并且写入一些数据到这个XML文件中。
/*
* 创建xml文件
*/ $info = array(
array('obj' => 'power','info' => 'power is shutdown'),
array('obj' => 'memcache','info' => 'memcache used than 90%'),
array('obj' => 'cpu','info' => 'cpu used than 95%'),
array('obj' => 'disk','info' => 'disk is removed')
);//用来写入的数据 $dom = new DOMDocument('1.0');
$dom->formatOutput = true;//格式化 $eventList = $dom->createElement('EventList');//创建根节点EventList
$dom->appendChild($eventList);//添加根节点 for($i = 0; $i < count($info); $i++){
$event = $dom->createElement('event');//创建节点event
$text = $dom->createTextNode('PHP'.$i);//创建文本节点,值为PHP0,PHP1...
$event->appendChild($text);//将文本节点添加到节点event,做为节点event的值 $attr_obj = $dom->createAttribute('obj');//创建属性obj
$attr_obj->value = $info[$i]['obj'];//为obj属性赋值
$event->appendChild($attr_obj);//将obj属性添加到event节点中,做为event节点的属性 $attr_info = $dom->createAttribute('info');
$attr_info->value = $info[$i]['info'];
$event->appendChild($attr_info); $eventList->appendChild($event);//将event节点添加到根节点EventList中
} //echo $dom->saveXML();
$dom->save('./t.xml');//保存信息到当前目录下的t.xml文件中
上面的代码段可以创建一个XML文件,并添加一些信息到这个文件中,包括值和属性,最终形成的文件为当前目录下的t.xml,可以看一下它的内容。
<?xml version="1.0"?>
<EventList>
<event obj="power" info="power is shutdown">PHP0</event>
<event obj="memcache" info="memcache used than 90%">PHP1</event>
<event obj="cpu" info="cpu used than 95%">PHP2</event>
<event obj="disk" info="disk is removed">PHP3</event>
</EventList>
读取XML信息&添加新的属性
以上一节创建的t.xml文件为操作对象,读取出t.xml文件中的信息,并给节点添加一个新的属性count,其值为1。
/*
* 读取xml文件信息,并添加新的属性
*/ $dom = new DOMDocument('1.0');
$dom->load('./t.xml');//加载要操作的文件
$list = $dom->getElementsByTagName('event');//获取event节点列表
foreach($list as $item){
$attr_obj = $item->getAttribute('obj');//获取属性obj的值
$attr_info = $item->getAttribute('info');
echo "<pre>Object:$attr_obj;Info:$attr_info;Value:{$item->nodeValue}</pre>";
$item->setAttribute('count',1);//添加新的属性count=1
}
$dom->save('./t.xml');//保存修改
看一下提取到的值:
Object:power;Info:power is shutdown;Value:PHP0 Object:memcache;Info:memcache used than 90%;Value:PHP1 Object:cpu;Info:cpu used than 95%;Value:PHP2 Object:disk;Info:disk is removed;Value:PHP3
再看一下现在的t.xml文件的内容,count属性已经添加上。
<?xml version="1.0"?>
<EventList>
<event obj="power" info="power is shutdown" count="1">PHP0</event>
<event obj="memcache" info="memcache used than 90%" count="1">PHP1</event>
<event obj="cpu" info="cpu used than 95%" count="1">PHP2</event>
<event obj="disk" info="disk is removed" count="1">PHP3</event>
</EventList>
修改节点属性&节点值
以上一节中的t.xml文件为操作对象,修改一下obj属性是cpu的节点的count值,新的值为count+1。
/*
* 修改某一个节点的属性和值
*/ $dom = new DOMDocument('1.0');
$dom->load('./t.xml');
$list = $dom->getElementsByTagName('event');
foreach($list as $item){
$attr_obj = $item->getAttribute('obj');
if($attr_obj == 'cpu'){//修改cpu的count属性,使其值+1
$attr_count = $item->getAttribute('count');//获取count属性的值
$item->setAttribute('count',$attr_count+1);//重置count属性的值
$item->nodeValue = 'Hello,Kitty';//重置节点的值
}
}
$dom->save('./t.xml');
操作后的t.xml文件如下,要以看到obj=cpu的节点的count属性已经改变,值也修改成功。
<?xml version="1.0"?>
<EventList>
<event obj="power" info="power is shutdown" count="1">PHP0</event>
<event obj="memcache" info="memcache used than 90%" count="1">PHP1</event>
<event obj="cpu" info="cpu used than 95%" count="2">Hello,Kitty</event>
<event obj="disk" info="disk is removed" count="1">PHP3</event>
</EventList>
删除节点
要添加就会有删除。以上节的t.xml文件为操作对象,删除obj=disk的节点。
/*
* 删除节点
*/ $dom = new DOMDocument('1.0');
$dom->load('./t.xml');
$list = $dom->getElementsByTagName('event');
foreach($list as $item){
if($item->getAttribute('obj') == 'disk'){//以obj=disk的节点为操作对象
$item->parentNode->removeChild($item);//删除节点
}
}
$dom->save('./t.xml');
看一下操作后的t.xml文件内容,obj=disk的节点已被成功删除。
<?xml version="1.0"?>
<EventList>
<event obj="power" info="power is shutdown" count="1">PHP0</event>
<event obj="memcache" info="memcache used than 90%" count="1">PHP1</event>
<event obj="cpu" info="cpu used than 95%" count="2">Hello,Kitty</event> </EventList>
向根节点中添加新的子节点
以上一节的t.xml为操作对象,向根节点EventList中添加一个新的子节点。
/*
* 向EventList中添加一个子节点
*/ $dom = new DOMDocument('1.0');
$dom->load('./t.xml');
$event_list = $dom->getElementsByTagName('EventList');//获取根节点
$event = $dom->createElement('event','lenovo');//新建节点
$event_list->item(0)->appendChild($event);//将新建节点添加到根节点中 $event_attr_obj = $dom->createAttribute('obj');
$event_attr_obj->value = 'lenovo';
$event->appendChild($event_attr_obj); $event_attr_info = $dom->createAttribute('info');
$event_attr_info->value = 'thinkpad t430';
$event->appendChild($event_attr_info); $dom->save('./t.xml');
看一下操作后的t.xml文件内容,新的子节点已经被插入到根节点中。
<?xml version="1.0"?>
<EventList>
<event obj="power" info="power is shutdown" count="1">PHP0</event>
<event obj="memcache" info="memcache used than 90%" count="1">PHP1</event>
<event obj="cpu" info="cpu used than 95%" count="2">Hello,Kitty</event> <event obj="lenovo" info="thinkpad t430">lenovo</event></EventList>
关于item($index)
item(index)是DOMNodeList类中的一个方法,它的做用是返回一个由索引指明的节点。而DOMDocument类中的getElementsByTagName(name)方法返回的正是一个DOMNodeList对象的实例,所以可以直接调用item(index)方法。以上节的t.xml为示例,如果e=dom−>getElementsByTagName(‘EventList′)获取EventList节点的信息,因为EventList节点是根节点,有且仅有一个,所以它调用item(index)时,索引只有index=0可用,因为它只有1个;而如果e=dom−>getElementsByTagName(‘event′)获取event节点的信息,因为event有4个,所以它调用item(index)时,索引$index={0,1,2,3},有4个值可以选。每个节点都包含多个属性,它可以以一种键值对数组的形式表现出来,如下所示:
object(DOMElement)#3 (18) {
["tagName"]=>
string(5) "event"
["schemaTypeInfo"]=>
NULL
["nodeName"]=>
string(5) "event"
["nodeValue"]=>
string(11) "Hello,Kitty"
["nodeType"]=>
int(1)
["parentNode"]=>
string(22) "(object value omitted)"
["childNodes"]=>
string(22) "(object value omitted)"
["firstChild"]=>
string(22) "(object value omitted)"
["lastChild"]=>
string(22) "(object value omitted)"
["previousSibling"]=>
string(22) "(object value omitted)"
["nextSibling"]=>
string(22) "(object value omitted)"
["attributes"]=>
string(22) "(object value omitted)"
["ownerDocument"]=>
string(22) "(object value omitted)"
["namespaceURI"]=>
NULL
["prefix"]=>
string(0) ""
["localName"]=>
string(5) "event"
["baseURI"]=>
string(36) "file:/H:/xampp/htdocs/demo/xml/t.xml"
["textContent"]=>
string(11) "Hello,Kitty"
}
也可以当做对象的属性来用,例如获取这个节点的值:
/*
* 关于item()
*/
$dom = new DOMDocument('1.0');
$dom->load('./t.xml');
$e = $dom->getElementsByTagName('event');
echo $e->item(2)->nodeValue;
//var_dump($e->item(2));
// $e = $dom->getElementsByTagName('EventList');
// var_dump($e->item(0));
//var_dump($e->item(0)->baseURI);
// for($i=0;$i<$e->length;$i++){
// echo $e->item($i)->nodeValue;
// }
PHP原生DOM对象操作XML'代码'的更多相关文章
- PHP原生DOM对象操作XML的方法解答
创建一个新的XML文件,并且写入一些数据到这个XML文件中. /** 创建xml文件*/ $info = array(array('obj' => 'power','info' => 'p ...
- jquer 使用原生DOM对象
js中使document.getElementById("ID"); Jquery中可以使用$("#id") 或者$("#id").get( ...
- jQuery 对象 与 原生 DOM 对象 相互转换
区别 jQuery 选择器得到的 jQuery对象 和 原生JS 中的document.getElementById() document.querySelector取得的 DOM对象 是两种不同类型 ...
- JQ对象和原生DOM对象
相同点:两者本质上都是DOM元素. 不同点:JQ对象是在原生DOM对象上进行了一次封装,使开发人员使用起来更简洁.高效. 两者之间用法也完全不同,很说初学者经常混淆. 其实区分两者并不难, 1.语法不 ...
- 原生JS中常用的Window和DOM对象操作汇总
一.常用的Window对象操作 Window对象中又包含了document.history.location.Navigator和screen几个对象,每个对象又有自己的属性方法,这里window可以 ...
- jQuery对象与JS原生dom对象之间的转换
jQuery就是JS的一个扩展库,工具库,提供很多方便快捷的方法,所以将JS对象转换为jQuery对象后,能更方便地操作这个对象.但是jQuery对象也不是万能的,有一些JS对象有的能,jQuery对 ...
- 第30天:DOM对象操作
JS包括三部分:ECMAscript.DOM(文档对象).BOM(浏览器对象) 一.DOM(文档对象)DOM树节点(元素.属性.标签.标记等都是节点) 二.访问节点 documment.getElem ...
- dom对象操作Html,Css
HTML: 1.不要再文档加载完使用document.write,这样会创建新的dom对象,原来的元素将被覆盖. 2.获取元素,通过getElementbyID; getElementbyTag(&q ...
- htm Dom对象与 Xml Dom对象的理解
html 是基于Xml的文档规范.是一种特殊的xml文档,这一点很重要 1.xml 文档的操作,java,c#,...各种语言都提供了很好的api对文档进行解析,操作.当然js 也不例外,提供了一系列 ...
随机推荐
- react学习总结
http://www.runoob.com/react/react-tutorial.html一般先看一些中文的简单的介绍和一些基本概念http://reactjs.cn/react/docs/get ...
- wemall app商城源码Fragment中监听onKey事件
wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享android开发Fragment中监听onK ...
- wxWidgets 的 Linux / Windows 混合开发环境
目标 建立一个开发 GUI 交互界面程序的环境,要求: 以 C/C++ 为主要程序设计语言. 最好能充分利用已有的 MFC 开发经验. 以 Linux 为主要开发环境.可以在 Windows 中编译并 ...
- Python中参数是传值,还是传引用?
在 C/C++ 中,传值和传引用是函数参数传递的两种方式,在Python中参数是如何传递的?回答这个问题前,不如先来看两段代码. 代码段1: def foo(arg): arg = 2 print(a ...
- 关于EasyUI 1.5版Datagrid组件在空数据时无法显示"空记录"提示的BUG解决方法
问题:jQuery easyUI中Datagrid,在表格数据加载无数据的时候,如何显示"无记录"的提示语? 解决jQuery EasyUI 1.5.1版本的Datagrid,在处 ...
- java线程的等待、通知机制【读书笔记】
代码示例: package com.baidu.nuomi.concurrent; import java.text.SimpleDateFormat; import java.util.Date; ...
- C#编写代码:求三个数中的最大数
static void Main(string[] args) { float x, y, z, temp; Console.Write(&q ...
- Java中的函数对象
初次听说java中的函数对象可能,比较的陌生.可以类比着来理解一下,人们常说java中没有了指针,殊不知,java中的对象引用就是指针,有时候我们说一个对象往往指的就是这个对象的引用,也就是说基本上把 ...
- Git修改提交注释
修改本地最近一次已提交的注释 git commit --amend 如果已经上传到了github上,因此github的提交和已修改的提交不一样,推送到远程可以用下面命令强制修改 git push or ...
- pcntl_fork 导致 MySQL server has gone away 解决方案
pcntl_fork 前连数据库,就会报 MySQL server has gone away 错误.原因是子进程会继承主进程的数据库连接,当mysql返回数据时,这些子进程都可以通过这个连接读到数据 ...