|
[XSL-LIST Mailing List Archive Home] [By Thread] [By Date] [Recent Entries] [Reply To This Message] Re: Merging nodes to process with FO
Hi,
Tempore 05:14:49, die 08/30/2005 AD, hinc in xsl-list@xxxxxxxxxxxxxxxxxxxxxx scripsit Russell Levy <russlevy@xxxxxxxxxx>: My problem is I can't do a for-each on either the unit or the occupant; if I do it on the unit, I'll only get one row for unit 1, and if I do it on the occupant, I won't get any rows for 2. I also want to be have it sorted by unit, so I wouldn't be able to do a for-each on all occupants, then another on all units that don't have an occupant. Why don't you just nest the loops instead of putting them adjacent to each other? Consider this little stysheet (change 'root' to a proper name) : <xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"><xsl:output method="text"/> <xsl:key name="occupant" match="occupant" use="unitid"/> <xsl:template match="root">
<xsl:for-each select="unit">
<xsl:variable name="unit" select="."/>
<xsl:variable name="occupants" select="key('occupant',id)"/>
<xsl:choose>
<xsl:when test="$occupants">
<xsl:for-each select="$occupants">
<xsl:value-of select="$unit/name"/> | <xsl:value-of select="name"/>
<xsl:text> </xsl:text>
</xsl:for-each>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$unit/name"/> | Vacant
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
</xsl:template></xsl:stylesheet>
|
PURCHASE STYLUS STUDIO ONLINE TODAY!Purchasing Stylus Studio from our online shop is Easy, Secure and Value Priced! Download The World's Best XML IDE!Accelerate XML development with our award-winning XML IDE - Download a free trial today! Subscribe in XML format
|

Cart








