四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

解析php DOMElement 操作xml 文檔的實現代碼

復制代碼 代碼如下:
/*<?xml version="1.0" encoding="UTF-8" standalone="no"?>
 <!-- css的樣式定義,不加點。如:name{color:red;} -->
<?xml-stylesheet type="text/css" href="css.css"?>
<!-- 引入dtd文檔定義文件 (根元素:班級)<!DOCTYPE 班級 SYSTEM "class.dtd" /> -->
<!-- <!DOCTYPE 班級[
<!ELEMENT 班級 (學生+)>
<!ELEMENT 學生 (名字,年齡,介紹)>
<!ELEMENT 名字 (#PCDATA)>
<!ELEMENT 年齡 (#PCDATA)>
<!ELEMENT 介紹 (#PCDATA)>
] /> -->
<班級>
<學生 number="101">
<名字>孫悟空</名字>
<名字>孫行者</名字>
<年齡>123</年齡>
<介紹><![CDATA[&*$%特殊字串^&#$&]]></介紹>
</學生>

<學生 number="10"2">
<名字>白骨精</名字>
<年齡>140</年齡>
<介紹>介紹內容</介紹>
</學生>
</班級>
*/
$xmldoc = new DOMDocument('1.0', 'UTF-8');
$xmldoc->load('datas.xml');

$itemsNodeList = $xmldoc->getElementsbyTagName('學生');
$itemElement = $itemsNodeList->item(0);//得到第一個完整的學生信息節點
$itemChildsNodeList = $itemElement->getElementsbyTagName('名字');//得到子節點“名字”,也許有多個名字
$itemChildNode = $itemChildsNodeList->item(0);//得到第一個名字節點
echo $itemChildNode->nodeValue;//輸出節點值

//封裝成函數
$nodeArr = array('名字', '年齡', '介紹');
function getNodeVal($xmldoc, $itemsName, $nodeArr){
    $items = $xmldoc->getElementsByTagName($itemsName);
     for($i=0; $i < $items->length; $i++){
        $item = $items->item($i);
        foreach($nodeArr as $node){
            $data[$i][] = $item->getElementsByTagName($node)->item(0)->nodeValue;
        }
    }
    return $data;
}

$data = getNodeVal($xmldoc, '學生', $nodeArr);
print_r($data);

復制代碼 代碼如下:
//添加節點
$xmldoc = new DOMDocument('1.0', 'UTF-8');
$xmldoc->load('datas.xml');
$items = $xmldoc->getElementsByTagName('班級')->item(0);//根節點
$student =  $xmldoc->createElement('學生');//創建一個新的學生節點
$stu_name = $xmldoc->createElement('名字','張三');
$stu_age = $xmldoc->createElement('年齡','15');
$stu_intro = $xmldoc->createElement('介紹','動手能力強且成績穩定');
$items->appendChild($student);
$student->appendChild($stu_name);
$student->appendChild($stu_age);
$student->appendChild($stu_intro);
$bytes = $xmldoc->save('datas.xml');
echo ($bytes)? "寫入了: $bytes 字節" : '保存失敗';

//刪除節點
$xmldoc = new DOMDocument('1.0', 'UTF-8');
$xmldoc->load('datas.xml');
$student = $xmldoc->getElementsByTagName('學生')->item(2);//直接找到要刪除的節點
$student->parentNode->removeChild($student);//父節點的刪除方法
$xmldoc->save('datas.xml');

//修改節點值
$student = $xmldoc->getElementsByTagName('學生')->item(2);
$student->getElementsByTagName('年齡')->item(0)->nodeValue += 10;
$student->setAttribute('id', '110');
$xmldoc->save('datas.xml');

//應用 Xpath 查找節點

$xml = new DOMDocument('1.0', 'UTF-8');
$xml->load('dat.xml');
$xpath = new DOMXPath($xml);
$nodeList = $xpath->query('/aaa/bbb/ddd/fff');
echo $nodeList->item(0)->nodeValue;

//SimpleXML 類操作 xml
/*
<?xml version="1.0" encoding="UTF-8"?>
<books>
<book house="清華出版">
<code>1001</code>
<price>200元</price>
<author>大明</author>
<title>天龍八部</title>
</book>
<book house="北大出版">
<code>1002</code>
<price>321元</price>
<author>張三</author>
<title>笑傲江湖</title>
</book>
<book house="人 民出版">
<code>1004</code>
<price>182元</price>
<author>李四</author>
<title>讀者</title>
</book>
</books>
*/
$xml = simplexml_load_file('books.xml');
$books = $xml->book;
echo $books[1]->title . $books[1]['house'];//直接指向第二本書
foreach($xml as $item){
    echo $item->title,' ',$item['house'],'<br/>';
}

php技術解析php DOMElement 操作xml 文檔的實現代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 新老澳门资料| infrustructure| 菊次郎的夏天钢琴谱简谱| 陕09j01图集| 性感美女写真视频| 无人区在线| 欧美成熟| 杨佑宁个人简历| 杯弓蛇影读后感| 里番在线看| 卜算子咏梅拼音| 妈妈的朋友未删减版| 张国立个人资料简介| 美国伦理女兵1| 民国奇探2出来了吗| 娄际成| 刘思维| 求职者| 毕福剑说的那句话| 依人在线视频| 负心人| 央视7套| 周杰伦《退后》歌词| 廖凡和莫小棋主演的一半火焰一半海水 | 丰崎爱生| 龙岭迷窟演员表| 东方卫视在线观看| 物理必修三目录图片| 免费看网站| 三浦亚沙妃| 小学智力测试题100题| 美女网站视频免费| 在爱的名义下| 汪汪队完整版全集免费| 画江湖之不良人第1季| 五年级下册数学期末试卷人教版| 乔治克鲁尼身高| 电影《心灵奇旅》| 小数点除法讲解视频| 曲丹个人资料简介| 高达w|