如何自动编号表行?

时间:2015-02-22 18:53:20

标签: xml xslt xmltable

我想生成一个名为“Position”的列,并自动显示每个驱动程序(1,2,3)的位置。我尝试使用<xsl:number />,但只是在XML中显示位置,我不希望这样。有什么想法吗?

XSLT代码:

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="html" indent="yes" doctype-public="-//W3C//DTD XHTML 1.1//EN" doctype-system="http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd" />
    <xsl:template match="/grid">
        <html xmlns="http://www.w3.org/1999/xhtml" >
            <body>
                <table border="1" width="100%" align="center">
                    <tr>
                        <th colspan="5">Clasificación</th>
                    </tr>
                    <tr>
                        <th>Piloto</th>
                        <th>Total</th>
                        <th>Imola</th>
                        <th>Monza</th>
                        <th>Silverstone</th>
                    </tr>               
                    <xsl:for-each select="driver">
                        <xsl:sort select="sum(points/*)" data-type="number" order="descending"/>
                        <tr>
                            <td><xsl:value-of select="name" /></td>
                            <td><xsl:value-of select="sum(points/*)" /></td>
                            <td><xsl:value-of select="points/imola" /></td>
                            <td><xsl:value-of select="points/monza" /></td>
                            <td><xsl:value-of select="points/silverstone" /></td>
                        </tr>
                    </xsl:for-each> 
                </table>
            </body>
        </html>
    </xsl:template>
</xsl:stylesheet>

XML CODE:

<grid>
    <driver>
        <name>Driver A</name>
        <points>
            <imola>10</imola>
            <monza>2</monza>
            <silverstone>10</silverstone>
        </points>
    </driver>
    <driver>
        <name>Driver B</name>
        <points>
            <imola>9</imola>
            <monza>6</monza>
            <silverstone>7</silverstone>
        </points>
    </driver>
    <driver>
        <name>Driver C</name>
        <points>
            <imola>8</imola>
            <monza>10</monza>
            <silverstone>5</silverstone>
        </points>
    </driver>
</grid>

1 个答案:

答案 0 :(得分:2)

这取决于你的意思是&#34;位置&#34;。你可以使用;

<xsl:value-of select="position()" />

或:

<xsl:value-of select="count(../driver[sum(points/*) > sum(current()/points/*)]) + 1" />

当两个或更多司机拥有相同数量的积分时,会出现差异。


  

第二个是完美的,但我不明白它是如何工作的。能够   你解释一下吗?

它计算点数多于当前点数的驱动程序数量。

  • 如果驱动程序位于第一位,则没有驱动程序 有更多的积分 - 结果是0(我们在那里添加1 ==&gt; 1st);

  • 如果驱动程序在第二位,那么有一个驱动程序有更多的点 - 所以结果是1(我们在那里添加1 ==&gt;第二个);

  • 如果两位车手排在第二位,那么对于他们两位车手来说,只有一位车手有更多积分 - 所以他们都排在第二位;下一位车手在他前面有三名车手,所以他最终排在第四位 - 没有人被标记为第三名。

请注意,您可以通过先在变量中存储点的总和,然后在表格中的两个位置使用变量来提高效率,例如:

<xsl:for-each select="driver">
    <xsl:sort select="sum(points/*)" data-type="number" order="descending"/>
    <xsl:variable name="pts" select="sum(points/*)" />
    <tr>
        <td><xsl:value-of select="count(../driver[sum(points/*) > $pts]) + 1" /></td>
        <td><xsl:value-of select="name" /></td>
        <td><xsl:value-of select="$pts" /></td>
        <td><xsl:value-of select="points/imola" /></td>
        <td><xsl:value-of select="points/monza" /></td>
        <td><xsl:value-of select="points/silverstone" /></td>
    </tr>
</xsl:for-each> 

不幸的是,它无法避免单独为排序计算相同的东西。