以下是我的样本xml数据
<?xml version="1.0"?>
<catalog>
<book>
<book NAME="ci_id">
<PVAL><![CDATA[78965]]></PVAL>
</book>
<author>testing</author>
<title>Md kaif khan</title>
<genre>kkkk</genre>
<price>5.95</price>
<publish_date>2016-09-10</publish_date>
<description>No...........</description>
</book>
<book>
<book NAME="ci_id">
<PVAL><![CDATA[78965]]></PVAL>
</book>
<author>asdfsaf</author>
<title>Md asdfsaf khan</title>
<genre>Age</genre>
<price>6.95</price>
<publish_date>2016-09-10</publish_date>
<description>Asd</description>
</book>
<book>
<book NAME="ci_id">
<PVAL><![CDATA[5210]]></PVAL>
</book>
<author>Test</author>
<title>Testing second</title>
<genre>Ttt</genre>
<price>8.94</price>
<publish_date>2013-10-15</publish_date>
<description>Nothing</description>
</book>
</catalog>
这里我的要求是添加多条记录 即,来自&lt;书&gt; ...&lt; /书&GT;基于id(即CDATA [78965])。
<?php
$xmlFileToLoad = dirname(__FILE__) .'/testing.xml';
$xmlFileToSave = 'testing-modified.xml';
$cdata_text = '
<book>
<book NAME="ci_id">
<PVAL><![CDATA[78965]]></PVAL>
</book>
<author>testing</author>
<title>First</title>
<genre>kk</genre>
<price>5.95</price>
<publish_date>2016-09-10</publish_date>
<description>Just i am testing.</description>
</book>
<book>
<book NAME="ci_id">
<PVAL><![CDATA[78965]]></PVAL>
</book>
<author>testing1</author>
<title>Second</title>
<genre>kone</genre>
<price>5.12</price>
<publish_date>2014-10-20</publish_date>
<description>i am testing One.</description>
</book>
';
$dom = new DOMDocument();
$dom->load($xmlFileToLoad);
$xpath = new DOMXPath($dom);
function findStopPointByName($xml, $query) {
$upper = "ABCDEFGHIJKLMNOPQRSTUVWXYZAZSCZCÓL";
$lower = "abcdefghijklmnopqrstuvwxyzazscznól";
$arg_query = "translate(text(), '$upper', '$lower')";
$q = "//book[book/PVAL[contains($arg_query, '$query')]]" ."\n";
return $xml->query($q);
}
foreach(findStopPointByName($xpath,'78965') as $node)
{
// Save parent - after removing node we will use it
$parent = $node->parentNode;
$parent->removeChild($node);
// Load XML from text. You cann't append text, only node
$data = new DOMDocument();
$data->loadXML($cdata_text);
// Import all new XML to our one and append to saved parent
$ndata = $dom->importNode($data->documentElement, true);
$parent->appendChild($ndata);
}
$dom->save($xmlFileToSave);
在$ cdata_text中的上述代码中,当我使用单个记录(&lt; book&gt; ..&lt; / book&gt;)时,它在目标文件中正确添加。但我需要添加两个记录(具有相同的ID(即78965,实际上在我的代码中,我使用xml中的特定id进行搜索,并使用$ cdata_text进行更新,当我使用单个记录时它正在更新,但现在我想添加多个相同id的记录(来自$ cdata_text)或者我可以说,我需要从xml文件中找到id并需要用$ cdata_text字符串更新它。
请指导我。
答案 0 :(得分:2)
您当前的源将片段字符串作为单独的文档加载。这将失败,因为格式良好的XML文档只能有一个文档元素节点。
文档片段是DOM中的特殊节点类型,因此您可以像创建任何其他节点一样创建和附加它。它有一个方法appendXml()
来解析XML片段字符串。
这是一个简单的例子:
$document = new DOMDocument();
$document->loadXml('<catalog/>');
$fragment = $document->createDocumentFragment();
$fragment->appendXml(
'<book><title>First</title></book>
<book><title>Second</title></book>'
);
$document->documentElement->appendChild($fragment);
echo $document->saveXml();
输出:
<?xml version="1.0"?>
<catalog><book><title>First</title></book>
<book><title>Second</title></book></catalog>