为了澄清标题,我有一个如下所示的 XML 文档:
<group>
<starter>Start</starter>
<backup1>Backup1</backup1>
</group>
<group>
<starter>Another starter</starter>
<backup1>Backup1</backup1>
<backup2>Backup2</backup2>
<backup3>Backup3</backup3>
<reserve>Reserve</reserve>
</group>
因此每个组可以有任意数量的 <backupN>
标签。我需要确保我的 XSLT 捕获所有这些并将它们重命名为“backup_n”。通常我的 XSLT 会应用符合以下内容的内容:
<xsl:for-each select="group/backup">
并循环该 xpath 选择。这显然是行不通的,因为即使只有 1 个备份,它仍然被命名为 <backup1>
并且也可以有任意数量的 <backupN>
标签。
像这样循环任意标签的最佳方法是什么?我正在使用 XSLT 1.0,因此无法真正使用 XSLT 2.0 的任何优点。
最佳答案
如果您想要名称以 backup
开头的所有元素,您可以使用
<xsl:for-each select="group/*[starts-with(local-name(), 'backup')]">
但具体取决于您想要生成的输出类型,使用模板匹配而不是 for-each
可能会更干净。
如果您特别想限制名称为“backup”后跟数字的元素(例如,不包括 backuptype
等内容),那么您可以添加到谓词
group/*[starts-with(local-name(), 'backup')
and number(substring(local-name(), 7)) = number(substring(local-name(), 7))]
(这看起来很奇怪,但诀窍是,如果 substring(local-name(), 7)
不是有效数字,则测试将变为 NaN = NaN
始终为 false - NaN
不等于任何内容,甚至不等于其本身)。
关于xml - 用于具有任意标签的 XML 文档的 XSLT,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19363134/