группировать по xml документу по дочернему элементу - PullRequest
0 голосов
/ 28 января 2020

У меня есть следующее xml. Это набор родительского узла записи, содержащий идентификаторы, количество и категорию.

<Data>
<record>
    <identifier>1000</identifier>
    <category>B</category>
    <quantity>90.00</quantity>
</record>
<record>
    <identifier>1000</identifier>
    <category>B</category>
    <quantity>50.00</quantity>
</record>
<record>
    <identifier>1001</identifier>
    <category>B</category>
    <quantity>13.00</quantity>
</record>
<record>
    <identifier>1002</identifier>
    <category>B</category>
    <quantity>100.00</quantity>
</record>

Мне нужно сгруппировать по элементу записи по дочернему «идентификатору». Ожидаемый вывод:

<Data>
<records>
    <record>
        <identifier>1000</identifier>
        <category>B</category>
        <quantity>90.00</quantity>
    </record>
    <record>
        <identifier>1000</identifier>
        <category>B</category>
        <quantity>50.00</quantity>
    </record>
</records>
<records>
    <record>
        <identifier>1001</identifier>
        <category>B</category>
        <quantity>13.00</quantity>
    </record>
</records>
<records>
    <record>
        <identifier>1002</identifier>
        <category>B</category>
        <quantity>100.00</quantity>
    </record>
</records>

Я использую этот xslt, но он не работает ни на уровне группировки.

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0">
<xsl:output method="xml" indent="yes" encoding="UTF-8" omit-xml-declaration="yes" />
<xsl:template match="Data">
    <Data>
        <xsl:for-each-group select="record" group-by="identifier">
            <records>
                <xsl:for-each select="current-group()">
                    <xsl:copy>
                        <xsl:value-of select="*" />
                    </xsl:copy>
                </xsl:for-each>
            </records>
        </xsl:for-each-group>
    </Data>
</xsl:template>

Как это исправить, чтобы это работало?

1 Ответ

0 голосов
/ 28 января 2020

Результат, который вы показываете, может быть достигнут путем небольшой корректировки (и упрощения) вашей таблицы стилей:

XSLT 2.0

<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform" >
<xsl:output method="xml" indent="yes" encoding="UTF-8" omit-xml-declaration="yes" />
<xsl:strip-space elements="*"/>

<xsl:template match="/Data">
    <Data>
        <xsl:for-each-group select="record" group-by="identifier">
            <records>
                <xsl:copy-of select="current-group()" />
            </records>
        </xsl:for-each-group>
    </Data>
</xsl:template>

</xsl:stylesheet>

Демонстрация: https://xsltfiddle.liberty-development.net/ncnu9B8/1

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...