使用XSLT将源XML过滤到目标XML

时间:2015-01-28 23:05:00

标签: xml xslt

由于生产问题,大量数据已损坏。好消息是我将所有数据都放在XML文件中,该文件的格式与提交数据更改的输入格式相同。我遇到的问题是一条记录需要一段时间来处理。我的清洁大师"有> 20,000条记录,只有530条已损坏。我有一个关键字段来标识我想要包含在目的地中的记录。如果只是在我指定的列表中,我如何在XSLT中包含输出节点?我不在乎我是否在XSLT中硬编码列表。

<recordSet>
  <record>
    <key>123</key>
    <val1>abc</val1>
    <val2>def</val2>
   </record>
  <record>
    <key>456</key>
    <val1>hij</val1>
    <val2>klm</val2>
   </record>
  <record>
    <key>789</key>
    <val1>nop</val1>
    <val2>qrs</val2>
   </record>
 </recordSet>

我们说我只想要带有键123和键789的记录。 谢谢。

1 个答案:

答案 0 :(得分:1)

  

我不在乎我是否在XSLT中硬编码列表。

以下是如何在XSLT 1.0中高效优雅地完成此任务:

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:exsl="http://exslt.org/common"
extension-element-prefixes="exsl">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:variable name="keys">
    <key>123</key>
    <key>789</key>
</xsl:variable>

<xsl:key name="record" match="record" use="key" />

<xsl:template match="/recordSet">
    <xsl:copy>
        <xsl:copy-of select="key('record', exsl:node-set($keys)/key)"/>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>

在XSLT 2.0中,这可以简化为:

<xsl:stylesheet version="2.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:variable name="keys">
    <key>123</key>
    <key>789</key>
</xsl:variable>

<xsl:key name="record" match="record" use="key" />

<xsl:template match="/recordSet">
    <xsl:copy>
        <xsl:copy-of select="key('record', $keys/key)"/>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>