如何汇总格式#,###。##

时间:2011-04-20 06:51:41

标签: xslt

全部,

哪里可以在xsl:stylesheet version =“1.0”中对1,185.00格式的数字求和? 例如:

<document>
 <number>1,185.00</number>
 <number>2,000.11</number>
</document>

结果应为:

<document>
 <sum>3185.11</sum>
<document>

1 个答案:

答案 0 :(得分:2)

检索resp时,您可以尝试使用translateformat-number。当您显示数据时。

我正在考虑sg。像这样:

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

    <xsl:template match="/">
        <document>
            <xsl:apply-templates select="document/number[1]">
                <xsl:with-param name="val" select="0"/>
            </xsl:apply-templates>
        </document>
    </xsl:template>

    <xsl:template match="number">
        <xsl:param name="val"/>
        <xsl:choose>
            <xsl:when test="not(following::number)">
                <sum>
                    <xsl:value-of select="format-number($val + translate(./text(),',',''), '###.##')"/>
                </sum>
            </xsl:when>
            <xsl:otherwise>
                <xsl:apply-templates select="following::number">
                    <xsl:with-param name="val" select="$val + translate(./text(),',','')"/>
                </xsl:apply-templates>
            </xsl:otherwise>
        </xsl:choose>
    </xsl:template>
</xsl:stylesheet>

为您的输入生成以下输出:

<?xml version='1.0' encoding='UTF-8' ?>
<document>
    <sum>3185.11</sum>
</document>