2016-11-22 117 views
0

我試過了所有方法,但沒有結果。我如何使用XSLT轉換 - 這樣的XML:Xslt遞歸轉換

<root> 
    <row>topic</row> 
    <row>Topic1</row> 
    <row>words</row> 
    <row>word1</row> 
    <row>word2</row> 
    <row>word3</row> 
    <row>words</row> 
    <row>word4</row> 
    <row>word5</row> 
    <row>word6</row> 
    <row>topic</row> 
    <row>Topic2</row> 
    <row>words</row> 
    <row>word7</row> 
    <row>word8</row> 
    <row>word9</row> 
    <row>topic</row> 
    <row>Topic3</row> 
    <row>words</row> 
    <row>word10</row> 
    <row>word11</row> 
    <row>word12</row> 
</root> 

在這樣的XML中?

<topic>Topic1 
    <words>word1word2word3word4word5word6</words> 
</topic> 
<topic>Topic2 
    <words>word7word8word9</words> 
</topic> 
<topic>Topic3 
    <words>word10word11word12</words> 
</topic> 

「主題」和「字」值經常發生在XML和我會第一組由主題,每個主題組中的字由「字」 ...提前

非常感謝!

+0

請問您的處理器支持XSLT 2.0嗎? –

+0

是的,它支持XSLT 2.0! – AmintaCode

回答

1

在XSLT 2.0,你可以如此簡單:

<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:template match="root"> 
    <xsl:copy> 
     <xsl:for-each-group select="row" group-starting-with="row[.='topic']"> 
      <topic> 
       <xsl:value-of select="current-group()[2]"/> 
       <words> 
        <xsl:value-of select="current-group()[position() gt 3]" separator=""/> 
       </words> 
      </topic> 
     </xsl:for-each-group> 
    </xsl:copy> 
</xsl:template> 

</xsl:stylesheet> 
+0

超級快速優雅的解決方案,謝謝! – AmintaCode

+0

什麼,如果不是的 TOPIC1 TOPIC2我有一個 bÇ等?我如何輸出元素中的每個單元格? @ michael.hor257k – AmintaCode

+0

@AmintaCode我沒有看到與當前問題的關係。你爲什麼不發佈一個新的? –