1

次の XML 構造を変換する XSLT を作成しようとしています。

<?xml version="1.0"?>
<rows>
    <row>       
                <e1>A1</e1>
                <l2>B1-01</l2>
                <q2>C1-1-1</q2>
                <n2>D111</n2>
    </row>
    <row>       
                <e1>A1</e1>             
                <l2>B1-01</l2>
                <q2>C1-1-2</q2>
                <n2>D112</n2>
    </row>
    <row>       
                <e1>A1</e1>             
                <l2>B1-02</l2>
                <q2>C1-2-1</q2>
                <n2>D121</n2>
    </row>
    <row>       
                <e1>A1</e1>             
                <l2>B1-02</l2>
                <q2>C1-2-2</q2>
                <n2>D122</n2>
    </row>  
    <row>       
                <e1>A2</e1>             
                <l2>B2-01</l2>
                <q2>C2-1-1</q2>
                <n2>D211</n2>
    </row>
    <row>       
                <e1>A2</e1>             
                <l2>B2-01</l2>
                <q2>C2-1-2</q2>
                <n2>D212</n2>
    </row>
    <row>       
                <e1>A2</e1>             
                <l2>B2-02</l2>
                <q2>C2-2-1</q2>
                <n2>D221</n2>
    </row>
    <row>       
                <e1>A2</e1>             
                <l2>B2-02</l2>
                <q2>C2-2-2</q2>
                <n2>D222</n2>
    </row>      
</rows>

これに

<?xml version="1.0"?>
<e1s xmlns:msxsl="urn:schemas-microsoft-com:xslt">
    <e1>A1</e1>
    <l2s>
        <l2>B1-01</l2>
        <q2s>
            <q2>D111</q2>
            <q2>D112</q2>
        </q2s>
        <l2>B1-02</l2>
        <q2s>
            <q2>D121</q2>
            <q2>D122</q2>
        </q2s>
    </l2s>
    <e1>A2</e1>
    <l2s>
        <l2>B2-01</l2>
        <q2s>
            <q2>D211</q2>
            <q2>D212</q2>
        </q2s>
        <l2>B2-02</l2>
        <q2s>
            <q2>D221</q2>
            <q2>D222</q2>
        </q2s>
    </l2s>
</e1s>

次のXSLTを試しました

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt">
    <xsl:output method="xml" version="1.0" indent="yes" omit-xml-declaration="no"/>
    <xsl:key name="ke1" match="row" use="e1" />
    <xsl:key name="kl2" match="row" use="concat(e1,'#',l2)" />  
    <xsl:template match="rows"> 
    <e1s>    
    <xsl:for-each select="row[generate-id() = generate-id(key('ke1', e1)[1])]">     
        <e1>
        <xsl:value-of select="e1"/>
        </e1>
        <l2s>       
        <xsl:for-each select="../row[generate-id() = generate-id(key('kl2', concat(e1,'#',l2))[1])]">
            <l2>
            <xsl:value-of select="l2"/>
            </l2>
            <q2s>               
                <xsl:for-each select="key('kl2', concat(e1,'#',l2))">
                    <q2>
                        <xsl:value-of select="n2" />
                    </q2>
                </xsl:for-each>
            </q2s>          
        </xsl:for-each>
        </l2s>      
    </xsl:for-each>
    </e1s>
    </xsl:template>
</xsl:stylesheet>

しかし、A1要素に「B2」が含まれているため、出力は良くありません。2日間試しましたが、キーが正しく取得できないようです。誰かがこれで私を助けてくれますか?

4

1 に答える 1

1

キーの定義は問題ありません。問題は の 2 番目のレベルにありますfor-each

<xsl:for-each select="../row[generate-id() = generate-id(key('kl2', concat(e1,'#',l2))[1])]">

外側の の周りのたびにfor-each、この選択はのすべての値のすべてe1#l2グループを処理しますe1。すべての行から選択するのではなく、現在の に一致する行のみを選択するように、ここでフィルタリングする必要があります。e1

<xsl:for-each select="key('ke1', e1)[generate-id() = generate-id(key('kl2', concat(e1,'#',l2))[1])]">

この変更により、正しい結果が得られます。

于 2013-11-19T11:50:39.763 に答える