witam,
posiadam plik xml z wpisami w formie:
<tabela>
<osoba>
<imie>Jan</imie>
<naz>Kowalski</naz>
<plec>m</plec>
<nr>44</nr>
<odl>30</odl>
<kier>N</kier>
</osoba>
</tabela>
i probuje posortowac w nim wpisy alfabetycznie jednak robiac dla kazdej litery osobna tabele
robie to w ten sposob:
<?xml version='1.0'?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html"
omit-xml-declaration="yes"/>
<xsl:template match="/">
<html>
<head><title>example</title></head>
<body>
<table border="1">
<tr>
<td>Imie</td>
<td>Naziwsko</td>
<td>Plec</td>
<td>Numer buta</td>
<td>Kilometry od Poznania</td>
<td>Kierunek</td>
</tr>
<xsl:for-each select="tabela/osoba">
<xsl:if test="starts-with(naz,'A')">
<tr>
<td><xsl:value-of select="imie"/></td>
<td><xsl:value-of select="naz"/></td>
<td><xsl:value-of select="plec"/></td>
<td><xsl:value-of select="nr"/></td>
<td><xsl:value-of select="odl"/></td>
<td><xsl:value-of select="kier"/></td>
</tr>
</xsl:if>
</xsl:for-each>
</table>
<br/>
<table border="1">
<tr>
<td>Imie</td>
<td>Naziwsko</td>
<td>Plec</td>
<td>Numer buta</td>
<td>Kilometry od Poznania</td>
<td>Kierunek</td>
</tr>
<xsl:for-each select="tabela/osoba">
<xsl:if test="starts-with(naz,'B')">
<tr>
<td><xsl:value-of select="imie"/></td>
<td><xsl:value-of select="naz"/></td>
<td><xsl:value-of select="plec"/></td>
<td><xsl:value-of select="nr"/></td>
<td><xsl:value-of select="odl"/></td>
<td><xsl:value-of select="kier"/></td>
</tr>
</xsl:if>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
jednak bedzie to duuuza ilosc kodu + fakt pojawiania sie pustych tabel w przypadku braku nazwiska na dana litere
jak zrobic to sprytniej?