In my XSLT transformation I have two analyze-strings that I need to use to process one node. They work fine one by one, but I don't know how to put them together.
XML document looks like this:
<article>
     <title>Article 1</title>
     <text><![CDATA[Lorem ipsum dolor sit amet, s consectetur adipiscing elit. Donec lorem diam, eleifend sed mollis id, condimentum in velit.
 
 Sed sit amet erat ac mauris adipiscing elementum. Pellentesque eget quam augue, id faucibus magna.
 
 Ut malesuada arcu eu elit sodales sodales. Morbi tristique porttitor tristique. Praesent eget vulputate dui. Cras ut tortor massa, at faucibus ligula.]]></text>
 </article>
 Here's my XSLT:
<xsl:template match="/">
     <html>
         <head>
             <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
             <title>Page title</title>
         </head>
         <body>
             <xsl:for-each select="article">
                 <h1><xsl:value-of select="./title"/></h1>
 
                 <!-- This adds paragraphs tags instead of empty lines in the text -->
                 <xsl:analyze-string select="./text" regex="
">
                     <xsl:non-matching-substring>
                         <p>
                             <xsl:value-of select="." disable-output-escaping="yes"/>
                         </p>
                     </xsl:non-matching-substring>
                 </xsl:analyze-string> 
 
                 <!-- This is Czech language specific. It looks for ' s ' (or other letter) and changes second space for  . So after that it is ' s '. -->
                 <xsl:analyze-string select="./text" regex="(\s[k/K/s/S/v/V/z/Z]\s)">
                     <xsl:matching-substring>
                         <xsl:text> </xsl:text>
                         <xsl:value-of select="replace(., ' ','')" disable-output-escaping="yes"/>
                         <xsl:text disable-output-escaping="yes"><![CDATA[ ]]></xsl:text>
                     </xsl:matching-substring>
                     <xsl:non-matching-substring>
                         <xsl:value-of select="." disable-output-escaping="yes"/>
                     </xsl:non-matching-substring>
                 </xsl:analyze-string>
             </xsl:for-each>
         </body>
     </html>
 </xsl:template>
 I need to apply both analyze-strings on the generated text so there are <p> tags for paragraphs and also added   on the right places.
My desired output would look like this:
<h1>Article 1</h1>    
 <p>Lorem ipsum dolor sit amet, s consectetur adipiscing elit. Donec lorem diam, eleifend sed mollis id, condimentum in velit.</p>
 <p>Sed sit amet erat ac mauris adipiscing elementum. Pellentesque eget quam augue, id faucibus magna.</p>
 <p>Ut malesuada arcu eu elit sodales sodales. Morbi tristique porttitor tristique. Praesent eget vulputate dui. Cras ut tortor massa, at faucibus ligula.</p>
 Any idea how to do this? Thank you for taking your time and trying to help me.
 
No comments:
Post a Comment