XSLT - 获取唯一的密钥并一步合并数据

时间:2014-08-26 12:42:34

标签: xml xslt distinct

我有一个XML文件,其中我有多年的字段,分别为Year1,Year2,Year3。

<?xml version="1.0" encoding="utf-16"?>
<data>
 <row>
<field fieldno="Name">Hello</field>
<field fieldno="Year1">2014</field>
<field fieldno="Year2">2015</field>
<field fieldno="Year3">2016</field>

</row>
 <row>
<field fieldno="Name">NotWelcome</field>
<field fieldno="Year1">2016</field>
<field fieldno="Year2">2017</field>
<field fieldno="Year3">2018</field>
</row>
<row>
<field fieldno="Name">Welcome</field>
<field fieldno="Year1">2014</field>
<field fieldno="Year2">2015</field>
<field fieldno="Year3">2016</field>
</row>
<row>
<field fieldno="Name">Goodbye</field>
<field fieldno="Year1">2015</field>
<field fieldno="Year2">2016</field>
<field fieldno="Year3">2017</field>
 </row>
</data>

我想在XML文件中看到所有出现的年份,但只有一次,所以对于我需要的文件:

2014 2015 2016 2017 2018

我读了一些关于muenchian分组的内容,并通过这种转换得到了一个字段的正确结果:

    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
      <xsl:key name="unique-year" match="row" use="field[@fieldno='Year1']" />
      <xsl:key name="unique-year2" match="row" use="field[@fieldno='Year2']" />
      <xsl:key name="unique-year3" match="row" use="field[@fieldno='Year3']" />

      <xsl:template match="data">
        <xsl:for-each select="row[count(. | key('unique-year', field[@fieldno='Year1'])[1]) = 1]">
          <xsl:sort select="field[@fieldno='Year1']" />
          <xsl:value-of select="field[@fieldno='Year1']" />
        </xsl:for-each>
      </xsl:template>
    </xsl:stylesheet>

但我真的不知道如何合并单个结果,所以我得到了一个整体结果。

我该如何管理?

另外,我不明白这条线,我只是根据我的要求采用了它,但我不知道这里发生了什么:

  <xsl:for-each select="row[count(. | key('unique-year', field[@fieldno='7015'])[1]) = 1]">

你们其中一个人对我有什么解释吗?

谢谢和亲切的问候,

亚历

1 个答案:

答案 0 :(得分:0)

以下样式表:

XSLT 1.0

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

<xsl:key name="field" match="field" use="." />

<xsl:template match="/data">
    <xsl:for-each select="row/field[@fieldno='Year1' or @fieldno='Year2' or @fieldno='Year3'][count(. | key('field', .)[1]) = 1]">
        <xsl:sort select="." data-type="number"/>
        <xsl:value-of select="." />
        <xsl:if test="position()!=last()">
            <xsl:text> </xsl:text>
        </xsl:if>
  </xsl:for-each>
</xsl:template>

</xsl:stylesheet>

应用于您的XML示例时,将返回:

2014 2015 2016 2017 2018

不确定你的真实情况,但在这种情况下是表达式:

row/field[@fieldno='Year1' or @fieldno='Year2' or @fieldno='Year3']

可以简化为:

row/field[@fieldno!='Name']

编辑:

要计算不同的值,请使用:

<xsl:value-of select="count(row/field[@fieldno='Year1' or @fieldno='Year2' or @fieldno='Year3'][count(. | key('field', .)[1]) = 1])" />

在同一个模板中(但在<xsl:for-each>元素之外)。