2016-12-29 15 views
0

これはHTMLである:XSLT:各シーケンシャルノードと一つのノードを繰り返し

<html> 
    <div> 
     <div class="theheader">The first header</div> 
    </div> 
    <div class="thecontent"> 
     <div class="col1">Col 1 </div> 
     <div class="col2">Col 2 </div> 
    </div> 
    <div class="thecontent"> 
     <div class="col1">Col 3 </div> 
     <div class="col2">col 4 </div> 
    </div> 
    <div> 
     <div class="theheader">The second header</div> 
    </div> 
    <div class="thecontent"> 
     <div class="col1">Col 5 </div> 
     <div class="col2">Col 6 </div> 
    </div> 
    <div class="thecontent"> 
     <div class="col1">Col 7 </div> 
     <div class="col2">Col 8 </div> 
    </div> 
</html> 

これはXSLある:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
    <xsl:output method="text" encoding="utf-8" omit-xml-declaration="yes" indent="no"/> 

    <xsl:template match="div[@class='theheader']" /> 

    <xsl:template match="div[@class='thecontent']"> 
     <xsl:value-of select="//div[@class='theheader']" /><xsl:text>: </xsl:text> 
     <xsl:value-of select="." /> 
     <xsl:text>&#10;</xsl:text> 
    </xsl:template> 

</xsl:stylesheet> 

これが出力される。

The first header: Col 1 Col 2 
The first header: Col 3 col 4 
The first header: Col 5 Col 6 
The first header: Col 7 Col 8 

所望の出力:

The first header: Col 1 Col 2 
The first header: Col 3 col 4 
The second header: Col 5 Col 6 
The second header: Col 7 Col 8 

どうすればできますか? XSLT 1.0を推奨します。

も試み:

<xsl:value-of select=".//div[@class='theheader']" /><xsl:text>: </xsl:text> 

(//前ドット)とないヘッダが出力されます。なぜ誰かが私に言うことができますか? 初版があまりに単純すぎたため、サンプルを編集しました。さて、SOはあまりにも多くのコードだと私に伝えます。この余剰なテキストが役立つことを願っています。

答えて

3

"theheader"にマッチするテンプレートから "thecontent"にマッチするテンプレートにヘッダーを出力して繰り返す必要があります。また、必要なdivを取得するには、preceding-sibling軸を使用する必要があります。

EDIT

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
    <xsl:output method="text" encoding="utf-8" omit-xml-declaration="yes" indent="no"/> 

    <xsl:template match="div[@class='theheader']" /> 

    <xsl:template match="div[@class='thecontent']"> 
     <xsl:value-of select="preceding-sibling::div[div/@class='theheader'][1]/div" /><xsl:text>: </xsl:text> 
     <xsl:for-each select="div"> 
      <xsl:value-of select="." /> 
     </xsl:for-each> 
     <xsl:text>&#10;</xsl:text> 
    </xsl:template> 

</xsl:stylesheet> 

このXSLTをお試しください:theheaderは潜在的に深く、より多くのレベルであることについてあなたのコメントを受けて、これらの式のいずれかに代わり

<xsl:value-of select="preceding-sibling::div[descendant::div/@class='theheader'][1]//div[@class='theheader']" /> 

<xsl:value-of select="preceding::div[@class='theheader'][1]" /> 
+0

感謝をしてみてください。それはうまくいったけど、私は私の例を単純化していた。今書き直されました。あなたは新しい版を見ることができることを願っています。 – Peter

+0

@Peter:ヘッダーはありますがコンテンツがない場合は、XSLTをどのように動作させますか?ちょうどエッジケースのためのあなたの要件を確認してください... – JohnLBevan

+0

ニース観測ジョン。内容は保証されています。 – Peter

関連する問題