全部,
哪里可以在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>
答案 0 :(得分:2)
检索resp时,您可以尝试使用translate
和format-number
。当您显示数据时。
<?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>