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)
-> + Use of before and after string (3) Sticky Topic
-> - How do I substitute element ty... (1)
-> + How does one add working days ... (4)
-> - Help, I have existing XLT and... (1)
-> + Need help on XSLT issue - (2)
-> + EDI to XML Conversion (7)
-> - XML To JSON Conversion using X... (1)
-> + Formatting Paragraphs to same ... (2)
-> - Grouping of records (1)
-> + Problems with xsd 1.1 (4)
-> + XML to HL7 mapping (3)
-> + XSLT 3 and Iterate (2)
-> + XSL-FO to PDF preview (3)
-> + java.lang.RuntimeException: Er... (2)
-> + Create Acroforms with Stylus X... (2)
-> + 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)
-- [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
Dexter McCloudSubject: how to compare a current value to a value in the next node
Author: Dexter McCloud
Date: 23 Sep 2004 11:11 AM
I am a fledgling developer in the XSLT world. So, I apologize if this
is an obvious question. I have XML, returned from my database, that will look like this:

<row row_type="order_info" order_id="63893" item_id="1146211"/>
<row row_type="order_info" order_id="63903" item_id="1146216"/>
<row row_type="order_info" order_id="63904" item_id="1146216"/>

I am generating HTML based on the values in the XML. I want to emit a
<TR> tag for every row of data; that's the easy part. However, if the
item_id is the same, I want to make the data part of the SAME <TR>.

Example using the data above:

<table>
<tr>
<td>order id</td>
<td>Item id</td>
</TR>
<tr>
<td>63893</td>
<td>1146211</td>
</TR>
<tr>
<td>63903<br>63904
</td>
<td>1146216</td>
</TR>
</table>

As you can see, because the "item_id (2nd column) is the same, I simply
combined the data inside the <TD> tags. Otherwise, each line will
occupy it's own <TR>.

But, how do I do this with XSLT?

Thanks,

Dexter (new user)


Documentitem_info.xml
example of typical data (4 rows)

Posttop
Minollo I.Subject: how to compare a current value to a value in the next node
Author: Minollo I.
Date: 23 Sep 2004 05:58 PM
[Song's reply wasn't rendered properly; here is a second attempt]
------------

Hi, Dexter

the task you described is very common and xslt 1.0 is not good in doing
that. The best way is to use key and generate-id to do grouping which I
guess is not very easy to understand if you are new to xslt. Here I will
show you an easier solution( but not the fastest) and hope it helps.

For each row element, we will check if it is already processed by
checking if it is the first element with the same @item_id. If it is, we
will work on this @item_id and find out all the row element with the
same @item_id and output all of them with <td> element. If it is not the
first, we know elements with this @item_id is already processed and we
don't do anything.

<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html"/>

<xsl:template match="/">
<table>
<xsl:for-each select="order/row">
<xsl:variable name="id" select="@item_id"/>
<xsl:if test="count(preceding-sibling::*[@item_id = $id])=0">
<tr>
<td>
<xsl:for-each select="../row[@item_id = $id]">
<xsl:value-of select="@order_id"/>
<xsl:if test="position() != last()">
<br/>
</xsl:if>
</xsl:for-each>
</td>
<td>
<xsl:value-of select="@item_id"/>
</td>
</tr>
</xsl:if>
</xsl:for-each>
</table>
</xsl:template>
</xsl:stylesheet>

Please note in xslt 2.0, this is very easy by using xsl:for-each-group.
We are going to ship next major release very soon and it will support
xslt2.0.

Song.

   
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.