我正在尝试将数据附加到XML Below中特定位置的末尾。
我的XML要长得多,但是,例如,我想将数据附加到标记为“删除”的部分的末尾。然后我会在“Total Tickets”的末尾添加不同的数据,但如果我能以某种方式弄清楚如何将数据附加到第一个孩子的末尾,我可以弄清楚其余的。
<report>
<sets>
<set>
<legend>Delete</legend>
<values>
<value date="2012-06-24" data="9"/>
<value date="2012-06-25" data="17"/>
<value date="2012-06-26" data="15"/>
<value date="2012-06-27" data="10"/>
<value date="2012-06-28" data="8"/>
</values>
</set>
<set>
<legend>Total Tickets</legend>
<values>
<value date="2012-06-24" data="412"/>
<value date="2012-06-25" data="416"/>
<value date="2012-06-26" data="423"/>
<value date="2012-06-27" data="405"/>
<value date="2012-06-28" data="280"/>
</values>
</set>
</sets>
</report>
下面是我编写的测试脚本以查看结果。在这个例子中,我试图在图例“删除”列表的末尾附加元素'值'和属性数据'12345'
<?php
$doc = new DOMDocument;
$doc->load('result.xml');
$test = $doc->getElementsByTagName("legend")->item(0);
echo $test->nodeValue.PHP_EOL; //should print Delete
if("Delete" == $test->nodeValue)
{
$newElement = $doc->createElement('value');
$theAttribute = $doc->createAttribute('date');
$theAttribute->value='12345';
$newElement->appendChild($theAttribute);
$doc->appendChild($newElement);
}
echo $doc->saveXML();
?>
我得到的结果是:
<report>
<sets>
<set>
<legend>Delete</legend>
<values>
<value date="2012-06-24" data="9"/>
<value date="2012-06-25" data="17"/>
<value date="2012-06-26" data="15"/>
<value date="2012-06-27" data="10"/>
<value date="2012-06-28" data="8"/>
</values>
</set>
<set>
<legend>Total Tickets</legend>
<values>
<value date="2012-06-24" data="412"/>
<value date="2012-06-25" data="416"/>
<value date="2012-06-26" data="423"/>
<value date="2012-06-27" data="405"/>
<value date="2012-06-28" data="280"/>
</values>
</set>
</sets>
</report>
<value date="12345"/>
我试图将数据显示为:
<report>
<sets>
<set>
<legend>Delete</legend>
<values>
<value date="2012-06-24" data="9"/>
<value date="2012-06-25" data="17"/>
<value date="2012-06-26" data="15"/>
<value date="2012-06-27" data="10"/>
<value date="2012-06-28" data="8"/>
<value date="12345"/>
</values>
</set>
不确定如何将数据添加到特定位置而不是XML的最后位置。
感谢任何人对此的帮助。
答案 0 :(得分:0)
试试这个:
原始XML文件(将其另存为'testFile.xml'):
<?xml version="1.0" encoding="utf-8"?>
<report>
<sets>
<set>
<legend>Delete</legend>
<values>
<value date="2012-06-24" data="9"/>
<value date="2012-06-25" data="17"/>
<value date="2012-06-26" data="15"/>
<value date="2012-06-27" data="10"/>
<value date="2012-06-28" data="8"/>
</values>
</set>
<set>
<legend>Total Tickets</legend>
<values>
<value date="2012-06-24" data="412"/>
<value date="2012-06-25" data="416"/>
<value date="2012-06-26" data="423"/>
<value date="2012-06-27" data="405"/>
<value date="2012-06-28" data="280"/>
</values>
</set>
</sets>
</report>
PHP代码:
<?php
$dom = new DomDocument( '1.0' );
$dom->preserveWhiteSpace = false;
$dom->formatOutput = true;
// load the xml file
$dom->load( 'testFile.xml', LIBXML_NOBLANKS );
$xpath = new DOMXPath($dom);
// prepare the xpath query to find the "values" node corresponding the
// "Delete" legend
$nodes = $xpath->query("//set[legend='Delete']/values");
// if found, append the new "value" node
if( $nodes->length ) {
$vNode = $dom->createElement( 'value' );
$vNodeAttr = $dom->createAttribute( 'date' );
$vNodeAttr->value = '12345';
$vNode->appendChild($vNodeAttr);
// append to "values"
$nodes->item(0)->appendChild( $vNode );
}
// i'm not saving it, just echo'ing
header( 'content-type: text/xml' );
echo $dom->saveXML();
?>
最终XML文件:
<?xml version="1.0" encoding="utf-8"?>
<report>
<sets>
<set>
<legend>Delete</legend>
<values>
<value date="2012-06-24" data="9"/>
<value date="2012-06-25" data="17"/>
<value date="2012-06-26" data="15"/>
<value date="2012-06-27" data="10"/>
<value date="2012-06-28" data="8"/>
<!--Node appended here-->
<value date="12345"/>
</values>
</set>
<set>
<legend>Total Tickets</legend>
<values>
<value date="2012-06-24" data="412"/>
<value date="2012-06-25" data="416"/>
<value date="2012-06-26" data="423"/>
<value date="2012-06-27" data="405"/>
<value date="2012-06-28" data="280"/>
</values>
</set>
</sets>
</report>
希望这有帮助。