XSL - 比较

时间:2016-09-21 12:10:34

标签: sum comparison xslt-1.0

我需要一些帮助来计算总和并添加一些比较复杂性来知道哪个元素应该是总和的一部分。

让我们采用以下XML

<REF>
   <amount>3</amount>
   <rate>7</rate>
</REF>
<A>
   <amount>10</amount>
   <rate>4</rate>
</A>
<A>
   <amount>-21</amount>
   <rate>2</rate>
</A>
<B>
   <amount>8</amount>
   <rate>1</rate>
</B>
<C>
   <amount>7</amount>
   <rate>32</rate>
</C>

我想在Total元素中显示每个金额的总和乘以每个相关汇率。 我想将我的总数分成两个元素:NegativeTotal和PositiveTotal。 如果值大于(金额*费率)REF对象,PostiveTotal将包含((金额*费率)的SUM) 如果值小于(金额*费率)REF对象,则NegativeTotal将包含((金额*费率)的SUM)

它应该给出以下输出

<Total>
    <PositiveTotal>
        264 <!-- 40 + 224 -->
    </PositiveTotal>
    <NegativeTotal>
        -34 <!-- -42 + 8 -->
    </NegativeTotal>
</Total>

如果可能,请告诉我 有关信息技术限制:XSLT 1.0

提前致谢

此致

1 个答案:

答案 0 :(得分:1)

我建议你这样做:

XSLT 1.0

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:exsl="http://exslt.org/common"
extension-element-prefixes="exsl">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>

<xsl:template match="/root">
    <!-- first pass -->
    <xsl:variable name="summands-rtf">
        <xsl:for-each select="*">
            <value>
                <xsl:value-of select="amount * rate" />
            </value>
        </xsl:for-each>
    </xsl:variable>
    <xsl:variable name="summands" select="exsl:node-set($summands-rtf)/value" />
    <!-- get the threshold -->
    <xsl:variable name="threshold" select="REF/amount * REF/rate" />
    <!-- output -->
    <Total>
        <PositiveTotal>
            <xsl:value-of select="sum($summands[. > $threshold])" />
        </PositiveTotal>
        <NegativeTotal>
            <xsl:value-of select="sum($summands[. &lt; $threshold])" />
        </NegativeTotal>
    </Total>
</xsl:template>

</xsl:stylesheet>

当应用于格式正确的 XML输入(具有单个根元素)时:

<强> XML

<root>
   <REF>
      <amount>3</amount>
      <rate>7</rate>
   </REF>
   <A>
      <amount>10</amount>
      <rate>4</rate>
   </A>
   <A>
      <amount>-21</amount>
      <rate>2</rate>
   </A>
   <B>
      <amount>8</amount>
      <rate>1</rate>
   </B>
   <C>
      <amount>7</amount>
      <rate>32</rate>
   </C>
</root>

结果将是:

<?xml version="1.0" encoding="UTF-8"?>
<Total>
   <PositiveTotal>264</PositiveTotal>
   <NegativeTotal>-34</NegativeTotal>
</Total>

请注意,REF金额和费率的乘积不包括在两个总数中的任何一个中,因为它既不高于也不低于阈值。同样,如果任何其他产品恰好等于阈值。它也将被排除在外。