Мне нужно будет преобразовать этот входной XML:
<Log1>
<Connection User="Peter" Host="Computer01" Port="22"/>
<Connection User="Peter" Host="Computer02" Port="22"/>
<Connection User="Peter" Host="Computer02" Port="80"/>
<Connection User="David" Host="Computer01" Port="8080"/>
<Connection User="David" Host="Computer01" Port="8080"/>
<Connection User="David" Host="Computer01" Port="8080"/>
<Connection User="David" Host="Computer03" Port="22"/>
<Connection User="David" Host="Computer04" Port="21"/>
</Log1>
В этот выходной XML:
<Log2>
<Event Name="David" Target="Computer01|Computer03|Computer04"/>
<Event Name="Peter" Target="Computer01|Computer02"/>
</Log2>
До сих пор я использовал мюнхианскую группировку и получил что-то вроде:
<Log2>
<Event Name="David" Target="Computer01|Computer01|Computer01|Computer03|Computer04"/>
<Event Name="Peter" Target="Computer01|Computer02|computer02"/>
</Log2>
Проблема в том, что я не могу избавиться от повторяющихся машин в своем выводе.
Вот мой XSLT:
<xsl:key name="myKey" match="Connection" use="@User"/>
<xsl:variable name="separator" select="'|'"/>
<xsl:template match="Log1">
<xsl:element name="Log2">
<xsl:for-each select="Connection[count(. | key('myKey', @User)[1]) = 1]">
<xsl:sort select="@User" />
<xsl:element name="Event">
<xsl:attribute name="Name">
<xsl:value-of select="@User" />
</xsl:attribute>
<xsl:attribute name="Target">
<xsl:for-each select="key('myKey', @User)">
<xsl:sort select="@Host" />
<xsl:value-of select="@Host" />
<xsl:if test="position() != last()">
<xsl:value-of select="$separator" />
</xsl:if>
</xsl:for-each>
</xsl:attribute>
</xsl:element>
</xsl:for-each>
</xsl:element>
</xsl:template>
Не могли бы вы, ребята, помочь мне с процессором XSLT 1.0?