0

XML 内の特定のノードとサブノードを属性別に並べ替えてグループ化する必要があります。

指定されたxml:

<Rechnung>
<somenodes />
<RechnungArtikelLieferinfos>
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind vergriffen und leider nicht mehr nachlieferbar:" InfoTypKurztext="NICHT_NACHLIEFERBAR" InfoTyp="2">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="12345" Bestellmenge="1.00" Artikelbezeichnung="Angebotsblatt someone de" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind im Rückstand:" InfoTypKurztext="RÜCKSTAND" InfoTyp="3">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="12345" Bestellmenge="2.00" Artikelbezeichnung="Angebotsblatt someoneother de" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>          
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind vergriffen und leider nicht mehr nachlieferbar:" InfoTypKurztext="NICHT_NACHLIEFERBAR" InfoTyp="2">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="54321" Bestellmenge="2.00" Artikelbezeichnung="Angebotsblatt something de" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>  
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind im Rückstand:" InfoTypKurztext="NICHT_AUF_LAGER" InfoTyp="0">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="5555" Bestellmenge="1.00" Artikelbezeichnung="some article" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>    
</RechnungArtikelLieferinfos>
<somemorenodes />
</Rechnung>

RechnungArtikelLieferinfo は、その属性 @Infotyp によってソートされます。同じ RechnungArtikelLieferinfo@Infotyp で、Artikelposition-Nodes をグループ化する必要があります (ここで意味を成しているといいのですが、英語は私の母国語ではありません)。

期待される結果:

<Rechnung>
<somenodes />
<RechnungArtikelLieferinfos>
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind im Rückstand:" InfoTypKurztext="NICHT_AUF_LAGER" InfoTyp="0">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="5555" Bestellmenge="1.00" Artikelbezeichnung="some article" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>  
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind vergriffen und leider nicht mehr nachlieferbar:" InfoTypKurztext="NICHT_NACHLIEFERBAR" InfoTyp="2">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="12345" Bestellmenge="1.00" Artikelbezeichnung="Angebotsblatt someone de" Katalogkennzeichen="99"/>
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="something" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="54321" Bestellmenge="2.00" Artikelbezeichnung="Angebotsblatt something de" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>
    <RechnungArtikelLieferinfo InfoTypLangtext="Folgende Artikel sind im Rückstand:" InfoTypKurztext="RÜCKSTAND" InfoTyp="3">
        <Artikelposition Absagekennzeichen="Allein im Rückstand" AbsagekennzeichenId="38" Artikeltyp="Beilage" ArtikeltypId="9" Zusatztextkennzeichen="" Zusatztext="" Bestellnummer="44444" Bestellmenge="2.00" Artikelbezeichnung="Angebotsblatt someoneother de" Katalogkennzeichen="99"/>
    </RechnungArtikelLieferinfo>  
</RechnungArtikelLieferinfos>
<somemorenodes />
</Rechnung>

私は XSL(T) に不慣れで、これに関するかなりのドキュメントを読みました。これを行う最善の方法は、XSLT 2.0 とそのグループ化オプション (for-each-group) を使用することだと思いますが、読み終わった後はやや混乱し、以前よりも混乱しています。特に、すべてのチュートリアルでは、構造を再構築する必要があると想定しているため、ノードと子を変更せずに移動するだけです。

事前にご協力いただきありがとうございます。

4

1 に答える 1

0

これは、for-each ループではなく、テンプレートだけで非常に簡単に実行できます (通常、XSLT では回避するのが最善です)。

この XML Playgroundで実行可能なデモ(出力ソースを参照)。

<!-- kick things off -->
<xsl:template match="Rechnung/RechnungArtikelLieferinfos">
    <xsl:copy>
        <xsl:apply-templates select='RechnungArtikelLieferinfo[not(preceding-sibling::RechnungArtikelLieferinfo/@InfoTyp = @InfoTyp)]'>
            <xsl:sort select='@InfoTyp' data-type='number' />
        </xsl:apply-templates>
    </xsl:copy>
</xsl:template>

<!-- RechnungArtikelLieferinfo nodes (unique only) -->
<xsl:template match='RechnungArtikelLieferinfo'>

    <!-- copy node, and... -->
    <xsl:copy>

        <!-- ...its attributes/text -->
        <xsl:copy-of select='@*|text()' />

        <!-- ...any Artikelposition nodes of same parent @InfoTyp -->
        <xsl:copy-of select='../RechnungArtikelLieferinfo[@InfoTyp = current()/@InfoTyp]/Artikelposition' />

    </xsl:copy>

</xsl:template>
于 2012-07-16T11:22:21.740 に答える