Вы можете попробовать следующий шаблон, используя метод Мюнхена - способ группировки элементов XSLT-1.0, хорошо работающий в веб-браузерах , таких как Firefox , IE или Chrome :
<?xml version='1.0' encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:key name="country" match="Album" use="Country" />
<xsl:template match="/Albums">
<html>
<body>
<xsl:for-each select="Album[generate-id() = generate-id(key('country',Country)[1])]">
<table border="2" bgcolor="transparent">
<tr bgcolor="grey">
<th>Artist</th>
<th>Title</th>
</tr>
<xsl:for-each select="key('country',Country)">
<xsl:sort select="Date" order="ascending"/> <!-- here you decide what elements are at the top -->
<!--printing table-->
<tr>
<td>
<xsl:value-of select="Artist" />
</td>
<td>
<xsl:value-of select="Name" />
</td>
</tr>
</xsl:for-each>
</table>
</xsl:for-each>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Приведенный выше шаблон упорядочивает ваши элементы в две таблицы. Один для каждого Country
примера. Если бы у вас было больше стран, конечно, было бы больше таблиц. Порядок элементов определяется xsl:sort
в xsl:for-each
.