2013-12-13 70 views
1

這是XML代碼,你可以看到字母和數字排序的這個項目組:分裂字母排序列表XSLT 1.0

<LIGHT_RANGE_LIST> 
    <RANGE>W19</RANGE> 
    <RANGE>W17</RANGE> 
    <RANGE>R15</RANGE> 
    <RANGE>R13</RANGE> 
    <RANGE>R11</RANGE> 
</LIGHT_RANGE_LIST> 

這是我的XSLT代碼:

<xsl:for-each select="RANGE"> 
    <span style="text-align:center;font-family:Univers Condensed; font-size:9pt; "> 
     <xsl:apply-templates/> 
    </span> 
</xsl:for-each> 

我已臨時適用此模板,獲得這樣的結果:

W19 
W17 
R15 
R13 
R11 

我的最終目標是讓下面的輸出:

W19 
R15 

每個字母,採取與最大數值的信 - 因爲它可能有一個字母(而不是兩個)

+0

請添加更多的你(如果而不是整個)XSLT樣式表。 –

回答

1

試着這麼做:

<?xml version="1.0" encoding="UTF-8"?> 
<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:key name="by_letter" match="RANGE" use="substring(., 1, 1)" /> 

<xsl:template match="/"> 
<div> 
    <!-- for each distinct letter --> 
    <xsl:for-each select="LIGHT_RANGE_LIST/RANGE[generate-id() = generate-id(key('by_letter', substring(., 1, 1))[1])]"> 
     <!-- process the subgroup --> 
     <xsl:for-each select="key('by_letter', substring(., 1, 1))"> 
      <xsl:sort select="substring(., 2)" data-type="number" order="descending"/> 
      <xsl:if test="position()=1"> 
       <span><xsl:value-of select="."/></span> 
      </xsl:if> 
     </xsl:for-each> 
    </xsl:for-each> 
</div> 
</xsl:template> 
</xsl:stylesheet> 

見解釋here

+0

謝謝我用它來解決我的問題。很好 。 –

+1

@francesco這是Muenchian分組方法的另一個例子,我在[我對上一個問題的回答]中描述了這個方法(http://stackoverflow.com/a/20547954/592139) - XSLT 1.0中的大多數分組問題都可以通過一些這種技術的變化,所以它是值得花一些時間來理解它。 –

+0

Ian這個XSLT是非常困難的......我不學習這個,我是一個VB程序員......並且創建這個XSLT項目而沒有學習,只有你和我的貢獻是一個目標。感謝您的寶貴幫助:-) –

0

最後,我研究了你的版本,我應用這個,這是類似的,但由我創建。謝謝您的合作。

變量名:
Lcorrente->當前字母
LSuccessiva->一個字母
Ncorrente->目前一些
Nsuccessiva->接下來數

<xsl:for-each select="RANGE"> 

<!-- Prendo le lettere--> 
<xsl:variable name="LCorrente" select="substring(.,1,1)"/>                               
<xsl:variable name="LSuccessiva" select="substring(preceding-sibling::RANGE[1] [preceding::IMMUTABLE_ID=$EF],1,1)"/> 

<!-- Prendo i numeri--> 
<xsl:variable name="NCorrente" select="number(substring(.,2,string-length(.)-1))"/> 
<xsl:variable name="NSuccessiva" select="number(substring(following-sibling::RANGE[1][preceding::IMMUTABLE_ID=$EF],2,string-length(following-sibling::RANGE[1][preceding::IMMUTABLE_ID=$EF])-1))"/> 

<xsl:when test="$LCorrente!=$LSuccessiva"> 
    <span style="font-family:Univers Condensed; font-size:9pt; color:orange; text-align:center;"> 
     <xsl:value-of select="$LCorrente"/>                   
    </span>  

    <span style="font-family:Univers Condensed; font-size:9pt; color:red; text-align:center; "> 
     <xsl:value-of select="$NCorrente"/> 
    </span> 
</xsl:when> 
</xsl:for-each> 
+0

如果你知道每個「組」(相同的第一個字母相鄰的項目)保證按降序編號順序,這種方法是好的 - 如果你需要應用排序給每個組提取最大數量,那麼你將不得不使用Muenchian風格的方法。在具有'xsl:sort'規範的'for-each'中,兄弟軸仍然引用原始文檔順序,而不是排序順序。 –

+0

謝謝IAn :-) xslt開始喜歡我:-) –