2016-08-30 3 views
0

を考えると、次のxml:XSLTマッチング

<items> 
<item id="item1"> 
    <description id="desc"> 
     <?RELAPP description="Relative" loc="start"?> 
     <heading id="h1" level="1">HEADING 1</heading> 
     <p id="p2" num="1">Paragraph A</p> 
     <?RELAPP description="Relative" loc="end"?> 
     <?SUMM description="Summary" loc="start"?> 
     <heading id="h2" level="1">HEADING 2</heading> 
     <p id="p3" num="2">Paragraph B</p> 
     <p id="p4" num="3">Paragraph C</p> 
     <heading id="h3" level="1">HEADING 3</heading> 
     <p id="p5" num="4">Paragraph D</p> 
     <p id="p6" num="5">Paragraph E</p> 
     <?SUMM description="Summary" loc="end"?> 
     <?drawings description="Drawings" loc="start"?> 
     <drawings> 
      <heading id="h4" level="1">HEADING 4</heading> 
      <p id="p7" num="6">Paragraph F</p> 
      <p id="p8" num="7">Paragraph G</p>   
     </drawings> 
     <?drawings description="Drawings" loc="end"?> 
    </description> 
</item> 
</items> 

私は間のテキストを取得しようとしている:

<?SUMM description="Summary" loc="start"?> 

<?SUMM description="Summary" loc="end"?> 

つまり:

HEADING 2 Paragraph B Paragraph C HEADING 3 Paragraph D Paragraph E 

見出しと段落の間にいくつかの区別があります。

<?xml version="1.0" encoding="ISO-8859-1"?> 
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output method="xml" indent="yes"/> 
<xsl:template match="/items"> 
    <myItems> 
     <xsl:apply-templates/> 
    </myItems> 
</xsl:template> 

<xsl:template match="item"> 
    <xsl:element name="info"> 
     <xsl:element name="summaryPI">   
      <xsl:for-each select="description/processing-instruction('SUMM')"> 
       <xsl:value-of select="."/> 
      </xsl:for-each>   
     </xsl:element> 
    </xsl:element> 
</xsl:template> 
</xsl:stylesheet> 

それだけでこの私を取得します:

私が思い付くことができました最高のXSLは、ある

<?xml version="1.0" encoding="UTF-8"?> 
<myItems> 
    <info> 
    <summaryPI>description="Summary" loc="start"description="Summary" loc="end"</summaryPI> 
    </info> 
</myItems> 

私は私がしたいテキストを取得するために使用する必要がありますどのようなルール?先行兄弟と兄弟姉妹と一緒に挑戦しましたが、うまく動けませんでした。私はバージョン1.0を使用しています。

+0

「*うまくいけば、見出しと段落の間にいくつかの分離を伴う*:2つの処理命令の間では、ノードは、これは使用して、もう少し効率的に作ることができる(彼らはあなたの例であると)兄弟であります"あなたが得たい**正確な**結果を投稿してみませんか? –

答えて

1

についての方法:あなたの入力例に適用

XSLT 1.0

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output method="text" encoding="UTF-8"/> 
<xsl:strip-space elements="*"/> 

<xsl:template match="/"> 
    <xsl:for-each select="//text()[preceding::processing-instruction('SUMM')[contains(., 'loc=&quot;start&quot;')]] 
            [following::processing-instruction('SUMM')[contains(., 'loc=&quot;end&quot;')]] "> 
     <xsl:value-of select="." /> 
     <xsl:if test="position()!=last()"> 
      <xsl:text>, </xsl:text> 
     </xsl:if> 
    </xsl:for-each> 
</xsl:template> 

</xsl:stylesheet> 

、結果は以下のようになります。

HEADING 2, Paragraph B, Paragraph C, HEADING 3, Paragraph D, Paragraph E 

:それができるならばすべてが

<xsl:for-each select="//*[preceding-sibling::processing-instruction('SUMM')[contains(., 'loc=&quot;start&quot;')]] 
         [following-sibling::processing-instruction('SUMM')[contains(., 'loc=&quot;end&quot;')]] "> 
+0

ありがとう!はい、それは仮定することができます。 – Oleg