就这么简单:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="*[not(name() = translate(name(),'0123456789',''))]"/>
</xsl:stylesheet>
当将此转换应用于文档时,某些元素名称中包含数字,如下所示:
<nums>
<num>01</num>
<num>02</num>
<A314>xxx</A314>
<b>
<c221/>
</b>
<num>03</num>
<num>04</num>
<num>05</num>
<num>06</num>
<num>07</num>
<num>08</num>
<num>09</num>
<num>10</num>
</nums>
产生了想要的正确结果,在这种情况下是:
<nums>
<num>01</num>
<num>02</num>
<b/>
<num>03</num>
<num>04</num>
<num>05</num>
<num>06</num>
<num>07</num>
<num>08</num>
<num>09</num>
<num>10</num>
</nums>
说明:
正确使用:
身份规则及其覆盖。
标准 XPathtranslate()
函数。