0

我正在尝试将数据附加到下面 XML 中特定位置的末尾。

我的 XML 更长,但例如,我想将数据附加到标有“删除”的部分的末尾。然后我会在“总票数”的末尾添加不同的数据,但如果我能以某种方式弄清楚如何将数据附加到第一个孩子的末尾,我就能弄清楚其余的。

<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 的最后。

我感谢任何人对此的帮助。

4

1 回答 1

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>

希望这可以帮助。

于 2012-07-16T06:30:32.860 回答