我需要检索父节点以及匹配特定属性值的子节点。输入 XML 是
<ErrorList>
<Table name="Table1" type="A">
<Error category="Minor">
<errorCode>100</errorCode>
<errorMessage>msg-100</errorMessage>
</Error>
<Error category="Major">
<errorCode>101</errorCode>
<errorMessage>msg-101</errorMessage>
</Error>
</Table>
<Table name="Table2" type="B">
<Error category="Fatal">
<errorCode>102</errorCode>
<errorMessage>msg-102</errorMessage>
</Error>
<Error category="Major">
<errorCode>105</errorCode>
<errorMessage>msg-101</errorMessage>
</Error>
</Table>
</ErrorList>
下面的 XSL 代码检索具有类别属性 Fatal 或 Minor 的错误节点:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output indent="yes" />
<xsl:template match="Error[@category = 'Fatal'] | Error[@category = 'Minor']">
<xsl:copy-of select="self::node()"/>
</xsl:template>
<xsl:template match="text()"/>
</xsl:stylesheet>
我得到的输出:
<Error category="Minor">
<errorCode>100</errorCode>
<errorMessage>msg-100</errorMessage>
</Error><Error category="Fatal">
<errorCode>102</errorCode>
<errorMessage>msg-102</errorMessage>
</Error>
预期的输出如下(需要为选择的子节点检索父表节点):
<Table name="Table1" type="A">
<Error category="Minor">
<errorCode>100</errorCode>
<errorMessage>msg-100</errorMessage>
</Error>
</Table>
<Table name="Table2" type="B">
<Error category="Fatal">
<errorCode>102</errorCode>
<errorMessage>msg-102</errorMessage>
</Error>
</Table>
您能否帮助我使用 xsl 以获得所需的输出。