XSLT - генерировать уникальный идентификатор для каждого отдельного значения - PullRequest
0 голосов
/ 01 августа 2020

Я пытаюсь создать уникальный идентификатор для каждого отдельного значения с помощью XSLT-1.0. У меня есть структура XSML, и каждый раз, когда я нахожу одно и то же значение в теге, я хотел бы сгенерировать уникальный идентификатор в теге вывода.

Входные XML:

<EMPLOYEES>
    <EMPLOYEE>
        <ID>1</ID>
        <NAME>AAA</NAME>
    </EMPLOYEE>
    <EMPLOYEE>
        <ID>2</ID>
        <NAME>AAA</NAME>
    </EMPLOYEE>
    <EMPLOYEE>
        <ID>3</ID>
        <NAME>BBB</NAME>
    </EMPLOYEE>
</EMPLOYEES>

Желаемый результат :

<RESULT>
    <EMPLOYEE>
        <ID>1</ID>
        <GROUP>1</GROUP>
    </EMPLOYEE>
    <EMPLOYEE>
        <ID>2</ID>
        <GROUP>1</GROUP>
    </EMPLOYEE>
    <EMPLOYEE>
        <ID>3</ID>
        <GROUP>2</GROUP>
    </EMPLOYEE>
</RESULT>

1 Ответ

0 голосов
/ 01 августа 2020

Вы можете использовать вариант Мюнчианская группировка :

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>
...