2017-02-15 74 views
0

對於每個<LineDetail>節點具有相同的值<CtryCd>並填充1 <LineDetail>且總和爲<Amt>。 但是,我還需要檢查<SI><TI>節點。總和的輸出標籤將基於<SI><TI> 節點。如果<SI><TI>的值均爲假,則會生成<Amt1>,如果<SI>的值爲true並且<TI>爲false,則會生成<Amt2>。 我創建了一個XSLT並且已經得到了總結。但是在我的輸出中仍然有一些缺失。XSLT 2.0中變量的分組

這是一個示例XML:

<Record> 
<Data> 
    <Process> 
     <Header> 
      <ID>22-BBB</ID> 
      <Date>2017-02-14</Date> 
      <ContactName>Abegail</ContactName> 
      <!-- some other elements --> 
     </Header> 
     <Detail> 
      <ID>22-CCC</ID> 
      <RequestedDate>2017-02-14</RequestedDate> 
      <!-- some other elements --> 
      <LineDetail> 
       <CtryCd>AF</CtryCd> 
       <SI>false</SI> 
       <TI>false</TI> 
       <Amt>11.11</Amt> 
      </LineDetail> 
      <LineDetail> 
       <CtryCd>SE</CtryCd> 
       <SI>true</SI> 
       <TI>false</TI> 
       <Amt>22.22</Amt> 
      </LineDetail> 
      <LineDetail> 
       <CtryCd>AF</CtryCd> 
       <SI>false</SI> 
       <TI>false</TI> 
       <Amt>33.33</Amt> 
      </LineDetail> 
      <LineDetail> 
       <CtryCd>AF</CtryCd> 
       <SI>true</SI> 
       <TI>false</TI> 
       <Amt>55.55</Amt> 
      </LineDetail>  
     </Detail> 
    </Process> 
</Data> 
</Record> 

產生的輸出:

<Record> 
<Data> 
    <Process> 
     <Header> 
      <ID>22-BBB</ID> 
      <Date>2017-02-14</Date> 
      <ContactName>Abegail</ContactName> 
      <!-- some other elements --> 
     </Header> 
     <Detail> 
      <LineDetail> 
       <CtryCd>AF</CtryCd> 
       <Amt1>99.99</Amt1> 
      </LineDetail> 
     </Detail> 
     <Detail> 
      <LineDetail> 
       <C<Amt2>22.22</Amt2> 
      </LineDetail> 
     </Detail> 
    </Process> 
</Data> 
</Record> 

預期輸出:

<Record> 
<Data> 
    <Process> 
     <Header> 
      <ID>22-BBB</ID> 
      <Date>2017-02-14</Date> 
      <ContactName>Abegail</ContactName> 
      <!-- some other elements --> 
     </Header> 
     <Detail> 
      <ID>22-CCC</ID> 
      <RequestedDate>2017-02-14</RequestedDate> 
      <!-- some other elements --> 
      <LineDetail> 
       <CtryCd>AF</CtryCd> 
       <Amt1>44.44</<Amt1> 
       <Amt2>55.55</Amt2> 
      </LineDetail> 
      <LineDetail> 
       <CtryCd>SE</CtryCd> 
       <Amt1>0</<Amt1> 
       <Amt2>22.22</Amt2> 
      </LineDetail>   
     </Detail> 
    </Process> 
</Data> 
</Record> 

XSLT:

<xsl:stylesheet version="2.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:key name="CtryCd" match="LineDetail" use="CtryCd"/> 
<!-- identity transform --> 
<xsl:template match="@*|node()"> 
    <xsl:copy> 
     <xsl:apply-templates select="@*|node()"/> 
    </xsl:copy> 
</xsl:template> 
<xsl:template match="Detail"> 
    <xsl:for-each-group select="LineDetail" group-by="CtryCd"> 
     <Detail> 
      <LineDetail> 
       <CtryCd> 
        <xsl:value-of select="CtryCd"/> 
       </CtryCd> 
       <xsl:if test="lower-case(SI)='false' and lower-case(TI)='false'"> 
        <Amt1> 
         <xsl:value-of select="sum(current-group()/Amt)"/> 
        </Amt1> 
       <xsl:if test="lower-case(SI)='true' and lower-case(TI)='false'"> 
        <Amt2> 
         <xsl:value-of select="sum(current-group()/Amt)"/> 
        </Amt2> 
       </xsl:if> 
       </xsl:if> 
       <xsl:if test="lower-case(SI)='true' and lower-case(TI)='false'"> 
        <Amt2> 
         <xsl:value-of select="sum(current-group()/Amt)"/> 
        </Amt2> 
       </xsl:if> 
      </LineDetail> 
     </Detail> 
    </xsl:for-each-group> 
</xsl:template> 
</xsl:stylesheet> 

回答

1

您目前的情況,如果只檢查組中的第一項。您真的需要它成爲實際總和聲明的一部分,作爲組中每個節點上的條件。

<Amt1> 
    <xsl:value-of select="sum(current-group()[lower-case(SI)='false' and lower-case(TI)='false']/Amt)"/> 
</Amt1> 

那麼你將不得不爲Amt2類似的聲明,檢測爲 「真」 與 「假」

試試這個XSLT

<xsl:stylesheet version="2.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:key name="CtryCd" match="LineDetail" use="CtryCd"/> 

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

<xsl:template match="Detail"> 
    <xsl:for-each-group select="LineDetail" group-by="CtryCd"> 
     <Detail> 
      <LineDetail> 
       <CtryCd> 
        <xsl:value-of select="CtryCd"/> 
       </CtryCd> 
       <Amt1> 
        <xsl:value-of select="sum(current-group()[lower-case(SI)='false' and lower-case(TI)='false']/Amt)"/> 
       </Amt1> 
       <Amt2> 
        <xsl:value-of select="sum(current-group()[lower-case(SI)='true' and lower-case(TI)='false']/Amt)"/> 
       </Amt2> 
      </LineDetail> 
     </Detail> 
    </xsl:for-each-group> 
</xsl:template> 
</xsl:stylesheet> 
+0

明白了。非常感謝。 – pinkpanther