XPath / XQuery:选择一个没有子节点的根节点

时间:2010-09-14 10:16:07

标签: xslt xpath xquery root-node xquery-sql

我有一个xml:

<Customer id="">
 <Name />
 <Address />
</Customer>

我想只选择一个没有子节点的根节点:

<Customer id=""/ >

XPath可以实现吗?

4 个答案:

答案 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=""/>