At 2005-11-19 23:32 +0100, my(_dot_)office(_at_)gmx(_dot_)de wrote:
i've got a problem with 2 files resulting in 1 trough xsl.
You don't say where you are having the problem ... how far did you get?
I want to parse a html-template that should be filled with data
from a xml-file.
Fine ...
The thing is that i don't want to put the html-stuff inside the xsl-file
because the template could be changed.
Fine ...
The result should be:
<!-- news template -->
<table>
<tr><td>Titel A</td><td>123</td></tr>
<tr><td>Titel B</td><td>456</td></tr>
<tr><td>Titel C</td><td>789</td></tr>
</table>
<!-- /news template -->
Could someone give me an example how to get this?
I hope the example below helps, but I'm not sure where you were
having the problem to start with so I don't know what to bring to
your attention.
. . . . . . . . Ken
T:\ftemp>type data.xml
<data>
<row class="col0">
<title>Title A</title>
<num>123</num>
</row>
<row class="col1">
<title>Title B</title>
<num>456</num>
</row>
<row class="col2">
<title>Title C</title>
<num>789</num>
</row>
</data>
T:\ftemp>type jolie.xml
<table>
<tr loop="row"><td myid="title">dummytitel</td><td myid="num">1234</td></tr>
</table>
T:\ftemp>type jolie.xsl
<?xml version="1.0" encoding="ISO-8859-1"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:output indent="yes"/>
<!--the external data to be added to the HTML source when building output-->
<xsl:variable name="datafile" select="document('data.xml')"/>
<!--found a table row that loops on the data file-->
<xsl:template match="tr[(_at_)loop]">
<!--remember the cells of the row for later-->
<xsl:variable name="cells" select="td"/>
<xsl:for-each select="$datafile/data/*[local-name(.)=current()/@loop]">
<!--building a row based on the specified row-oriented element-->
<tr>
<!--need to remember the row context when doing the cells-->
<xsl:variable name="row" select="."/>
<xsl:for-each select="$cells">
<td>
<!--match the cell's element name as asked for in attribute-->
<xsl:value-of select="$row/*[local-name(.)=current()/@myid]"/>
</td>
</xsl:for-each>
</tr>
</xsl:for-each>
</xsl:template>
<xsl:template match="@*|node()"><!--identity for all other nodes-->
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
T:\ftemp>xslt jolie.xml jolie.xsl con
<?xml version="1.0" encoding="utf-8"?>
<table>
<tr>
<td>Title A</td>
<td>123</td>
</tr>
<tr>
<td>Title B</td>
<td>456</td>
</tr>
<tr>
<td>Title C</td>
<td>789</td>
</tr>
</table>
T:\ftemp>
--
Upcoming XSLT/XSL-FO hands-on courses: Denver,CO March 13-17,2006
World-wide on-site corporate, govt. & user group XML/XSL training.
G. Ken Holman mailto:gkholman(_at_)CraneSoftwrights(_dot_)com
Crane Softwrights Ltd. http://www.CraneSoftwrights.com/s/
Box 266, Kars, Ontario CANADA K0A-2E0 +1(613)489-0999 (F:-0995)
Male Cancer Awareness Aug'05 http://www.CraneSoftwrights.com/s/bc
Legal business disclaimers: http://www.CraneSoftwrights.com/legal
--~------------------------------------------------------------------
XSL-List info and archive: http://www.mulberrytech.com/xsl/xsl-list
To unsubscribe, go to: http://lists.mulberrytech.com/xsl-list/
or e-mail: <mailto:xsl-list-unsubscribe(_at_)lists(_dot_)mulberrytech(_dot_)com>
--~--