これと同じくらい簡単です:
<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()
関数。