В качестве ссылки я следую этой статье о Muenchian Grouping Method.Уникальные узлы фильтра XSLT внутри группы с использованием метода группировки Muenchian
В моей проблеме в пределах каждой группы некоторые значения для узла <forename>
могут быть дублированы, в то время как я хочу фильтровать уникальные значения. Я пробовал применять критерии выбора forename[not(.=preceding-sibling::forename)]
, но это не работает, так как я вижу дубликаты на выходе.
XSLT, который я тестирую, следует (что в основном точно так же, как в статье выше, строка «изолированная», где применяется дополнительный фильтр).
Я, очевидно, ошибаюсь. В чем проблема?
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output indent="yes" method="text"/>
<xsl:key name="contacts-by-surname" match="contact" use="surname" />
<xsl:template match="records">
<xsl:for-each select="contact[count(. | key('contacts-by-surname', surname)[1]) = 1]">
<xsl:sort select="surname" />
<xsl:value-of select="surname" />
<xsl:for-each select="key('contacts-by-surname', surname)">
<xsl:sort select="forename" />
<xsl:value-of select="forename[not(.=preceding-sibling::forename)]" />
</xsl:for-each>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
работает как очарование! Теперь мне нужно только посмотреть на это и понять это .. спасибо! –