我有一个xml:
<Customer id="">
<Name />
<Address />
</Customer>
我想只选择一个没有子节点的根节点:
<Customer id=""/ >
XPath可以实现吗?
答案 0 :(得分:2)
不,这在XPath中是不可能的。
您不能选择没有子节点的节点,因为没有子节点它将是一个不同的节点,因此您不会从原始文档中选择一个节点。
要创建您想要的输出,您需要使用允许您创建新节点的语言,因此您无法在XPath中执行此操作。您可以使用XQuery创建新节点,这应该可以工作:
element {fn:node-name(/*)} {/*/@*}
答案 1 :(得分:2)
XPath不会改变任何源XML文档,这是设计。
要从现有XML文档生成新的XML文档,需要转换。
XSLT专门用于将一组树(包括XML文档)转换为结果树。
此转化:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes"/>
<xsl:template match="/*">
<xsl:copy>
<xsl:copy-of select="@*"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
应用于提供的XML文档:
<Customer id="">
<Name />
<Address />
</Customer>
生成想要的正确结果:
<Customer id=""/>
答案 2 :(得分:0)
$doc = new DOMDocument();
$doc->loadHTML($str);
$xPath = new DOMXpath($doc);
$xPathQuery = "//text()[contains(translate(.,'abcdefghijklmnopqrstuvwxyz', 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'), '<Customer id=\"\">')]";
$elements = $xPath->query($xPathQuery);
if($elements->length > 0){
foreach($elements as $element){
print "Found: " .$element->nodeValue."<br />";
}
答案 3 :(得分:0)
这个XQuery表达式:
element {name(/*)} {/*/@*}
输出:
<?xml version="1.0" encoding="UTF-8"?><Customer id=""/>