Вы можете использовать вариант Мюнчианская группировка :
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:key name="emp-by-name" match="EMPLOYEE" use="NAME" />
<xsl:template match="/EMPLOYEES">
<RESULT>
<xsl:for-each select="EMPLOYEE">
<xsl:copy>
<xsl:copy-of select="ID"/>
<GROUP>
<xsl:value-of select="generate-id(key('emp-by-name', NAME)[1])"/>
</GROUP>
</xsl:copy>
</xsl:for-each>
</RESULT>
</xsl:template>
</xsl:stylesheet>
Формат уникального идентификатора зависит от используемого вами процессора: например, используя libxslt
, вы можете увидеть следующий результат:
<?xml version="1.0" encoding="UTF-8"?>
<RESULT>
<EMPLOYEE>
<ID>1</ID>
<GROUP>idm86101615952</GROUP>
</EMPLOYEE>
<EMPLOYEE>
<ID>2</ID>
<GROUP>idm86101615952</GROUP>
</EMPLOYEE>
<EMPLOYEE>
<ID>3</ID>
<GROUP>idm86101613584</GROUP>
</EMPLOYEE>
</RESULT>
, а MSXML
может дать:
<?xml version="1.0"?>
<RESULT>
<EMPLOYEE>
<ID>1</ID>
<GROUP>IDOECYH2JCFIENET332KVV31ACSEILRTQLIHKWOCNC1WN5QJBD3AH</GROUP>
</EMPLOYEE>
<EMPLOYEE>
<ID>2</ID>
<GROUP>IDOECYH2JCFIENET332KVV31ACSEILRTQLIHKWOCNC1WN5QJBD3AH</GROUP>
</EMPLOYEE>
<EMPLOYEE>
<ID>3</ID>
<GROUP>IDZZBORVA3LQGFPDQLO51JC1X1JDCTYLF430BB43GE1YQ1D54SHZSB</GROUP>
</EMPLOYEE>
</RESULT>