XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
+ Stylus Studio Technical Forum (14621)
+ Website Feedback (249)
- XSLT Help and Discussion (7625)
-> + How to change XSLT parameter s... (3)
-> + how to change format of the da... (2)
-> + Search "Next 8 Results " doesn... (2)
-> - Support for Git (1)
-> + newbee (8)
-> + How to substitute element or t... (2)
-> + Xalan support in x16? (2)
-> + The context item for axis step... (5)
-> - ASP to XSL (1)
-> + xsl report, with xml feed, SVG... (7)
-> + XSLT code to transform CSV typ... (2)
-> + Make xstl file working in brow... (4)
-> + identity template, result-docu... (6)
-> - identity template and xsl:resu... (1)
-> + java.lang.RuntimeException: Er... (5)
-> + How to check matching parenthe... (2)
-> - Error only on using xalan:eval... (1)
-> + XSLT not displaying SOAP respo... (2)
-> + How do i delete the node from ... (2)
-> + How to break xslt lines to mak... (4)
-> - Marge node using attribute val... (1)
-> - Replce utf to unicode using xs... (1)
-> - getting different instances of... (1)
-> + XML to Flat (4)
-> + non breaking space   in e... (2)
-> - How can i attach a empty names... (1)
-> + Cannot find a matching 1-argum... (7)
-> - get value from different docum... (1)
-> + How can I change the XML heade... (2)
-> + Stylus Studio and Datapower (9)
-> + Generate XML form a XSD (2)
-> + There is no way to run xslt tr... (3)
-> + XML-Source NS is copied into t... (3)
-> + new guy attempting xslt (2)
-> + XML 2011 question (7)
-> + Manipulating XML with external... (2)
-> + removing duplicates from xml w... (8)
-> + Wnat to use presence of tag t... (2)
-> + modifing Andrew Welch's csv 2 ... (5)
-> + Can't use (or see) XSLT or WYS... (3)
-> + Delete the xsi:nil attribute ... (2)
-> + FOTY0012: Cannot get the typed... (20)
-> + XSLT Mapper - Two way xslt map... (2)
-> + EDI (5)
-> + XSL Test for lack of XML eleme... (4)
-> + Trouble Calling a java functio... (4)
-> + How to generate EDI 997 (2)
-> + followup on tokenize with /r (5)
-> + tokenize a string with \r (4)
-> + How to convert XML to XLS file... (2)
-> - How to convert XML to XLS file... (1)
-> + how to pass value to xsl for t... (3)
-> + entity expansion liimit exceed... (4)
-> + Creating XSLT Stylesheet (2)
-> + Create XSLT from XSD (2)
-> + How to remove nodes from xml b... (4)
-> + Highlighting text in XSL file (4)
-> - XSLT to Excel, predefine cell ... (1)
-> + CSaxon8Driver issue...time out (2)
-> + Is it possible to generate a X... (2)
-> + Is there any tool which genera... (2)
-> + xslt to html producing double ... (2)
-> - ADD 2 XML 2 Generate Single XM... (1)
-> + converting XML1 to XML2 struct... (2)
-> + How to remove the name space i... (2)
-> + Dump Payload into String (4)
-> + Converting Global EDIFACT into... (2)
-> + Auto mapping of XSLT? (3)
-> + Numbering a list broken into m... (3)
-> + help in xsl:analyze-string (2)
-> + Use XSLT with SOAP (2)
-> + Order of Processing Child Elem... (2)
-> + XSL finding a node based on va... (2)
-> + grouping a group? (11)
-> + Query on Looping (5)
-> + java.lang.Assertionerror_: Slo... (7)
-> + CONVERT SQL Server data to XML... (11)
-> + Error using "xsltproc" command... (3)
-> + XML refresh via web broswer (3)
-> + XSL-mapping usage for csv file... (4)
-> + form controls with xslt (2)
-> + Stylus Studio 2011 XML Enterpr... (2)
-> + Looping through Itema and gett... (2)
-> + Image src through System Varia... (3)
-> + XSL-mapping usage for csv file... (3)
-> + How to achieve UTF-8 encoding ... (2)
-> + sorting Using JavaScript (6)
-> + Display values from .xml horiz... (5)
-> + query on xslt for-each (3)
-> + query on xslt for-each (2)
-> + issue for First occurance (2)
-> + XSL: Mapping 2 XSD to 1 XSD (2)
-> + xslt mapper looses linkage fro... (2)
-> - How to Modify only few nodes a... (1)
-> + XSLT autocomplete function (2)
-> + i need to display dynamic list... (2)
-> + How to group when source has m... (11)
-> - Using EXCEL to create XSLT for... (1)
-> + Mapper generating XSLT, popula... (2)
-> + multiple columns (2)
-- [1-20] [21-40] [41-60] Next
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Nilesh ChavanSubject: need help in XSLT programming
Author: Nilesh Chavan
Date: 17 May 2011 02:23 PM
Hello,

my requirement is to trasnform one form of XML into another form. The i/p data does not have correct levelling and looping. The levels are identified based on the attribute CLASS.

Here's my input data:

<?xml version="1.0"?>
<HTML>
<BODY LANG="EN-US" STYLE="text-justify-trim:punctuation">
<DIV CLASS="WordSection1">
<P CLASS="ahead" STYLE="margin-left:0in;text-indent:0in">A</P>
<P CLASS="ahead" STYLE="margin-left:0in;text-indent:0in"></P>
<P CLASS="Main">
<B>ABSOLUTE DEEDS AS MORTGAGES,</B> 2.01
</P>
<P CLASS="Main"></P>
<P CLASS="Main">
<B>ACCELERATION OF OBLIGATION,</B> 5.01 to5.04. (<I>See</I> <B>DEFAULT AND ACCELERATION OFOBLIGATION</B>)
</P>
<P CLASS="Main"></P>
<P CLASS="Main">
<B>AFFIDAVITS</B>
</P>
<P CLASS="Sub1">Attorneys' fees</P>
<P CLASS="Sub2">Affidavit of independent counsel in support ofaward, Form p. 503</P>
<P CLASS="Sub1">Costs, affidavit as to, Form p. 504</P>
<P CLASS="Sub1">Financial affidavit, Form p. 452</P>
<P CLASS="Sub2">Constructive service</P>
<P CLASS="Sub3">Publication, service by</P>
<P CLASS="Sub4">Affidavit demonstrating due diligence,11.08</P>
<P CLASS="Sub2">Default judgment against defendant who hasn'tanswered</P>
<P CLASS="Sub3">Non-military affidavit, 11.10, Form p.466</P>
<P CLASS="Sub1">Summary judgment motion, affidavits supporting,13.03, Form p. 484</P>
<P CLASS="Sub1"></P>
<P CLASS="Main">
<B>AFFIRMATIVE DEFENSES</B>
</P>
<P CLASS="Sub1">
Avoidances to defenses, 27. (<I>See</I><B>AVOIDANCES</B>)
</P>
<P CLASS="Sub1">
Defenses generally. (<I>See</I><B>DEFENSES</B>)
</P>
<P CLASS="Sub2">Breach of contract, statute of frauds</P>
<P CLASS="Sub3">Affirmative defenses not precluded, 29.03</P>
</DIV>
</BODY>
</HTML>
-------------------------

The corresponding sample o/p is as foollws:

<?xml version="1.0"?>
<em:index>
<title>Index</title>
<title-alt use4="r-running-hd">INDEX</title-alt>
<title-alt use4="l-running-hd">INDEX</title-alt>
<in:body>
<level0>
<letter>A</letter>
<level1><B>ABSOLUTE DEEDS AS MORTGAGES,</B> 2.01</level1>
<level1></level1>
<level1><B>ACCELERATION OF OBLIGATION,</B> 5.01 to5.04. (<I>See</I> <B>DEFAULT AND ACCELERATION OFOBLIGATION</B>)</level1>
<level1></level1>
<level1><B>AFFIDAVITS</B>
<level2> Attorneys' fees
<level3> Affidavit of independent counsel in support ofaward, Form p. 503</level3>
</level2>
<level2> Costs, affidavit as to, Form p. 504 </level2>
<level2> Financial affidavit, Form p. 452
<level3> Constructive service
<level4> Publication, service by
<level5> Affidavit demonstrating due diligence,11.08 </level5>
</level4>
</level3>
<level3> Default judgment against defendant who hasn'tanswered
<level4> Non-military affidavit, 11.10, Form p.466</level4>
</level3>
</level2>
<level2> Summary judgment motion, affidavits supporting,13.03, Form p. 484</level2>
<level2></level2>
</level1>
<level1> AFFIRMATIVE DEFENSES
<level2> Avoidances to defenses, 27. (<I>See</I><B>AVOIDANCES</B>)</level2>
<level2> Defenses generally. (<I>See</I><B>DEFENSES</B>)
<level3> Breach of contract, statute of frauds
<level4> Affirmative defenses not precluded, 29.03</level4>
</level3>
</level2>
</level1>
</level0>
</in:body>
</em:index>
--------------------

I have written an xslt for this but it not able doing the transformation correctly. Please help me with this as this is very urgent and critical.

Her's my sample XSLT:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>

<xsl:template match="@* | node()">
<!--<xsl:copy>-->
<xsl:apply-templates select="@* | node() "/>
<!--</xsl:copy>-->
</xsl:template>

<xsl:template match="HEAD"/>
<xsl:template match="B | I">
<xsl:apply-templates/>
</xsl:template>


<xsl:template match="DIV" >
<xsl:copy>
<xsl:apply-templates select="@* | P[@CLASS = 'ahead'] "/>
</xsl:copy>
</xsl:template>

<xsl:template match="P[@CLASS = 'ahead']" >
<xsl:variable name="vContents" select="normalize-space(.)"/>
<xsl:choose>
<xsl:when test="string-length($vContents) &gt; 0" >
<xsl:element name="LEVEL0">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<xsl:apply-templates select="following-sibling::P" />
</xsl:element>
</xsl:when>
<xsl:otherwise>
<xsl:apply-templates select="following-sibling::P"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>

<xsl:template match="P[@CLASS = 'Main']" >
<xsl:variable name="vContents" select="normalize-space(.)"/>
<xsl:choose>
<xsl:when test="string-length($vContents) &gt; 0" >
<xsl:element name="LEVEL1">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<!--<xsl:apply-templates select="following-sibling::P[@CLASS = 'Sub1'] " />-->
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Main')] " />
</xsl:element>
</xsl:when>
<xsl:otherwise>
<xsl:element name="LEVEL1"></xsl:element>
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Main')] " />

</xsl:otherwise>
</xsl:choose>

</xsl:template>

<xsl:template match="P[@CLASS = 'Sub1']" >
<xsl:variable name="vContents" select="normalize-space(.)"/>
<xsl:choose>
<xsl:when test="string-length($vContents) &gt; 0" >
<xsl:element name="LEVEL2">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Sub1')]" />
</xsl:element>
</xsl:when>
<xsl:otherwise>
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Sub1')] " />
</xsl:otherwise>
</xsl:choose>
</xsl:template>

<xsl:template match="P" >
<xsl:variable name="Curr_Level" select="translate(@CLASS, 'Sub', '') + 1"/>
<xsl:variable name="Prec_Level">
<xsl:value-of select="translate(preceding-sibling::P[1]/@CLASS, 'Sub', '') + 1 "/>
</xsl:variable>
<xsl:variable name="Foll_Level">
<xsl:value-of select="translate(following-sibling::P[1]/@CLASS, 'Sub', '') + 1"/>
</xsl:variable>

<xsl:variable name="vTempLevel" select="concat('Sub',$Curr_Level)"/>

<xsl:choose>
<xsl:when test="$Prec_Level &lt; $Curr_Level">
<xsl:element name="{concat('LEVEL', $Curr_Level)}">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<xsl:if test="not($Curr_Level &gt; $Foll_Level) ">
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Sub1')]" />
</xsl:if>
</xsl:element>
</xsl:when>

<xsl:when test="$Prec_Level = $Curr_Level">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<xsl:if test="not($Curr_Level &gt; $Foll_Level) ">
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Sub1')]" />
</xsl:if>
</xsl:when>

<xsl:otherwise>
<xsl:element name="{concat('LEVEL', $Curr_Level)}">
<xsl:copy>
<xsl:value-of select="."/>
</xsl:copy>
<xsl:if test="not($Curr_Level &gt; $Foll_Level)">
<xsl:apply-templates select="following-sibling::P[1][not(@CLASS = 'Sub1')]" />
</xsl:if>
</xsl:element>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>


Attaching the sample i/p, o/p and XSLT for ur reference.

Please help me write this XSLT to get the desired o/p. Thanks!!

-Nilesh Chavan.
nilesh.chavan@lexisnexis.com


Unknowninput(16).xml
Input File

Unknownoutput(9).xml
output

Unknownconversion.xsl
my XSLT

Postnext
(Deleted User) Subject: need help in XSLT programming
Author: (Deleted User)
Date: 17 May 2011 04:42 PM
Good Luck, Nilesh. I've been trying to accomplish the same thing and have posted numerous times with no assistance from Stylus Studio. I can't even seem to find documentation to tell me what my errors mean.

I would never, ever recommend Stylus Studio to anyone.

Suzanne

Posttop
Nilesh ChavanSubject: need help in XSLT programming
Author: Nilesh Chavan
Date: 18 May 2011 04:59 PM
I have found the solution. It's working perfectly fine. I know there's lot of manual thing in this but atleast better than nothing :)

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.