> 백엔드 개발 > PHP 튜토리얼 > PHP 기본 DOM 객체가 XML을 조작하는 방법에 대한 자세한 설명

PHP 기본 DOM 객체가 XML을 조작하는 방법에 대한 자세한 설명

高洛峰
풀어 주다: 2023-03-03 22:46:01
원래의
1456명이 탐색했습니다.

XML 유형 파일을 운영하기 위해 PHP에는 처리를 위한 내장 DOM 객체 세트가 있다는 것은 누구나 알고 있습니다. 생성부터 수정, 삭제까지 XML 작업은 DOM 개체의 함수를 사용하여 수행할 수 있습니다. 다음 글에서는 샘플 코드를 통해 조작 방법을 소개하고 있으니, 도움이 필요한 친구들이 함께 살펴보도록 하겠습니다.

1. 만들기

새 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(&#39;event&#39;);//创建节点event
 $text = $dom->createTextNode(&#39;PHP&#39;.$i);//创建文本节点,值为PHP0,PHP1...
 $event->appendChild($text);//将文本节点添加到节点event,做为节点event的值
  
 $attr_obj = $dom->createAttribute(&#39;obj&#39;);//创建属性obj
 $attr_obj->value = $info[$i][&#39;obj&#39;];//为obj属性赋值
 $event->appendChild($attr_obj);//将obj属性添加到event节点中,做为event节点的属性
  
 $attr_info = $dom->createAttribute(&#39;info&#39;);
 $attr_info->value = $info[$i][&#39;info&#39;];
 $event->appendChild($attr_info);
  
 $eventList->appendChild($event);//将event节点添加到根节点EventList中
}
  
//echo $dom->saveXML();
$dom->save(&#39;./t.xml&#39;);//保存信息到当前目录下的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>
로그인 후 복사

2. XML 정보 읽기 및 새 속성 추가

이전 섹션에서 생성한 t.xml 파일이 작업 개체이고, t.xml 파일에 있는 정보를 읽어옵니다. 그리고 값이 1인 노드에 새 속성 개수를 추가합니다.

/*
 * 读取xml文件信息,并添加新的属性
 */
  
$dom = new DOMDocument(&#39;1.0&#39;);
$dom->load(&#39;./t.xml&#39;);//加载要操作的文件
$list = $dom->getElementsByTagName(&#39;event&#39;);//获取event节点列表
foreach($list as $item){
 $attr_obj = $item->getAttribute(&#39;obj&#39;);//获取属性obj的值
 $attr_info = $item->getAttribute(&#39;info&#39;);
 echo "<pre class="brush:php;toolbar:false">Object:$attr_obj;Info:$attr_info;Value:{$item->nodeValue}
"; $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>
로그인 후 복사

3. 노드 속성 및 노드 값 수정 ​​

이전 섹션의 t.xml 파일은 obj 속성이 있는 노드의 count 값을 수정합니다. 새로운 값은 count+1입니다.

/*
 * 修改某一个节点的属性和值
 */
  
$dom = new DOMDocument(&#39;1.0&#39;);
$dom->load(&#39;./t.xml&#39;);
$list = $dom->getElementsByTagName(&#39;event&#39;);
foreach($list as $item){
 $attr_obj = $item->getAttribute(&#39;obj&#39;);
 if($attr_obj == &#39;cpu&#39;){//修改cpu的count属性,使其值+1
  $attr_count = $item->getAttribute(&#39;count&#39;);//获取count属性的值
  $item->setAttribute(&#39;count&#39;,$attr_count+1);//重置count属性的值
  $item->nodeValue = &#39;Hello,Kitty&#39;;//重置节点的值
 }
}
$dom->save(&#39;./t.xml&#39;);
로그인 후 복사

작업 후 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>
로그인 후 복사

4. 노드 삭제

추가하시면 삭제됩니다. 위 섹션의 t.xml 파일을 작업 개체로 사용하여 obj=disk인 노드를 삭제합니다.

/*
 * 删除节点
 */
  
$dom = new DOMDocument(&#39;1.0&#39;);
$dom->load(&#39;./t.xml&#39;);
$list = $dom->getElementsByTagName(&#39;event&#39;);
foreach($list as $item){
 if($item->getAttribute(&#39;obj&#39;) == &#39;disk&#39;){//以obj=disk的节点为操作对象
  $item->parentNode->removeChild($item);//删除节点
 }
}
$dom->save(&#39;./t.xml&#39;);
로그인 후 복사

작업 후 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中添加一个子节点
 */
  
$dom = new DOMDocument(&#39;1.0&#39;);
$dom->load(&#39;./t.xml&#39;);
$event_list = $dom->getElementsByTagName(&#39;EventList&#39;);//获取根节点
$event = $dom->createElement(&#39;event&#39;,&#39;lenovo&#39;);//新建节点
$event_list->item(0)->appendChild($event);//将新建节点添加到根节点中
  
$event_attr_obj = $dom->createAttribute(&#39;obj&#39;);
$event_attr_obj->value = &#39;lenovo&#39;;
$event->appendChild($event_attr_obj);
  
$event_attr_info = $dom->createAttribute(&#39;info&#39;);
$event_attr_info->value = &#39;thinkpad t430&#39;;
$event->appendChild($event_attr_info);
  
$dom->save(&#39;./t.xml&#39;);
로그인 후 복사

작업 후 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>
로그인 후 복사

5. item($index) 정보

item(index)는 DOMNodeList 클래스의 메서드로, 해당 기능은 인덱스에 의해 지정된 노드를 반환하는 것입니다. DOMDocument 클래스의 getElementsByTagName(name) 메소드는 DOMNodeList 객체의 인스턴스를 반환하므로 item(index) 메소드를 직접 호출할 수 있습니다. 위 섹션의 t.xml을 예로 들면, e=dom−>getElementsByTagName('EventList')가 EventList 노드의 정보를 가져오는 경우 EventList 노드가 루트 노드이고 하나만 있기 때문에 item(index)를 호출합니다. index는 1개만 있으므로 index=0에서만 사용할 수 있습니다. e=dom−>getElementsByTagName('event')는 4개의 이벤트가 있으므로 이벤트 노드의 정보를 가져옵니다. , item(index)를 호출하면 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(&#39;1.0&#39;);
$dom->load(&#39;./t.xml&#39;);
$e = $dom->getElementsByTagName(&#39;event&#39;);
echo $e->item(2)->nodeValue;
//var_dump($e->item(2));
// $e = $dom->getElementsByTagName(&#39;EventList&#39;);
// var_dump($e->item(0));
//var_dump($e->item(0)->baseURI);
// for($i=0;$i<$e->length;$i++){
//  echo $e->item($i)->nodeValue;
// }
로그인 후 복사

요약

위 내용은 이 기사의 전체 내용입니다. 이 기사의 내용이 PHP를 배우거나 사용하는 모든 사람에게 도움이 되기를 바랍니다


PHP의 기본 DOM 개체가 XML을 조작하는 방법에 대한 자세한 설명을 보려면 PHP 중국어 웹사이트의 관련 기사를 참고하세요!


관련 라벨:
xml
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿