XSLT使用XML中的多个列进行排序

时间:2018-05-31 18:55:27

标签: xml sorting xslt

我的XML看起来像 -

    <?xml version='1.0' encoding='UTF-8'?>
<root>
    <row>
        <col1>Plan ID</col1>
        <col2>472064672</col2>
        <col3>18007</col3>
        <col4>1</col4>
        <col5>MARGARET</col5>
        <col6>PRESLEY</col6>
        <col7>20161216</col7>
        <col8/>
        <col9/>
        <col10>Pre-Tax </col10>
        <col11/>
        <col12>750</col12>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180501</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>Plan ID</col1>
        <col2>472064672</col2>
        <col3>18007</col3>
        <col4>1</col4>
        <col5>MARGARET</col5>
        <col6>PRESLEY</col6>
        <col7>20161216</col7>
        <col8/>
        <col9/>
        <col10>Pre-Tax Defrl%</col10>
        <col11>0</col11>
        <col12/>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180501</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>Plan ID</col1>
        <col2>214196103</col2>
        <col3/>
        <col4>1</col4>
        <col5>PETER</col5>
        <col6>JOHNSON</col6>
        <col7/>
        <col8/>
        <col9/>
        <col10>Pre-Tax </col10>
        <col11/>
        <col12>0</col12>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180502</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>Plan ID</col1>
        <col2>214196103</col2>
        <col3/>
        <col4>1</col4>
        <col5>PETER</col5>
        <col6>JOHNSON</col6>
        <col7/>
        <col8/>
        <col9/>
        <col10>Pre-Tax Defrl%</col10>
        <col11>16.29</col11>
        <col12/>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180502</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
</root>

我想对这个XML进行排序,使得对于每组col2值,应该对xml进行排序,使得如果col11的值为0且col12为空,则col11或col12为0的行首先出现,然后是在col11或col12中具有非零值的那些。

所以我的输出看起来像 -

    <root>
      <row>
        <col1>666919</col1>
        <col2>214196103</col2>
        <col3/>
        <col4>1</col4>
        <col5>PETER</col5>
        <col6>JOHNSON</col6>
        <col7/>
        <col8/>
        <col9/>
        <col10>Pre-Tax </col10>
        <col11/>
        <col12>0</col12>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180502</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>666919</col1>
        <col2>214196103</col2>
        <col3/>
        <col4>1</col4>
        <col5>PETER</col5>
        <col6>JOHNSON</col6>
        <col7/>
        <col8/>
        <col9/>
        <col10>Pre-Tax Defrl%</col10>
        <col11>16.29</col11>
        <col12/>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180502</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>666919</col1>
        <col2>472064672</col2>
        <col3>18007</col3>
        <col4>1</col4>
        <col5>MARGARET</col5>
        <col6>PRESLEY</col6>
        <col7>20161216</col7>
        <col8/>
        <col9/>
        <col10>Pre-Tax Defrl%</col10>
        <col11>0</col11>
        <col12/>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180501</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
    <row>
        <col1>666919</col1>
        <col2>472064672</col2>
        <col3>18007</col3>
        <col4>1</col4>
        <col5>MARGARET</col5>
        <col6>PRESLEY</col6>
        <col7>20161216</col7>
        <col8/>
        <col9/>
        <col10>Pre-Tax </col10>
        <col11/>
        <col12>750</col12>
        <col13/>
        <col14/>
        <col15/>
        <col16/>
        <col17/>
        <col18/>
        <col19/>
        <col20/>
        <col21/>
        <col22/>
        <col23/>
        <col24/>
        <col25/>
        <col26/>
        <col27/>
        <col28> </col28>
        <col29/>
        <col30>20180501</col30>
        <col31>2</col31>
        <col32/>
        <col33/>
        <col34/>
    </row>
</root>

1 个答案:

答案 0 :(得分:0)

试试这个XSLT。这将检查col11是零还是空,然后布尔表达式将为false,这意味着它首先被排序。同样适用于col12

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:output method="xml" />

  <xsl:template match="@*|node()">
      <xsl:copy>
          <xsl:apply-templates select="@*|node()" />
      </xsl:copy>
  </xsl:template>

  <xsl:template match="root">
    <xsl:copy>
        <xsl:apply-templates select="row">
            <xsl:sort select="col2" />
            <xsl:sort select="boolean(number(col11))" />
            <xsl:sort select="boolean(number(col12))" />
        </xsl:apply-templates>
    </xsl:copy>
  </xsl:template>
</xsl:stylesheet>