xsltでmuenchian-groupingを実行しているときに、キーがどのように生成されるかについては、まだ答えが見つかりません。私が見つけた例はすべて、非常に単純なxmlファイルを持っています。次のxmlファイルがあるとします。
<?xml version="1.0" encoding="UTF-8"?>
<despatch-advice>
<message-id>2012041715435517181</message-id>
<message-creation>2012-04-17T15:43:55.000+02:00</message-creation>
<originatingFlow>DespatchAdvice</originatingFlow>
<shipment>
<transport-mode>Sea</transport-mode>
<transport-id>1111</transport-id>
<order-line>
<order>123</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>ME</selling-code>
</order-line>
</shipment>
<shipment>
<transport-mode>Sea</transport-mode>
<transport-id>2222</transport-id>
<order-line>
<order>456</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>ME</selling-code>
</order-line>
<order-line>
<order>789</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>ME</selling-code>
</order-line>
<order-line>
<order>832</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>XM</selling-code>
</order-line>
</shipment>
<shipment>
<transport-mode>Air</transport-mode>
<transport-id>333</transport-id>
<order-line>
<order>781</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>XM</selling-code>
</order-line>
<order-line>
<order>789</order>
<order-date>2012-01-17+01:00</order-date>
<selling-code>XM</selling-code>
</order-line>
</shipment>
私がやりたいのは、各出荷の販売コードごとに注文明細をグループ化することです。
xsltファイルで、キーを次のように定義します。
<xsl:key name="groups" match="order-line" use="selling-code"/>
そして、xmlファイルの最初の部分を作成した後、次のようにします。
<xsl:for-each select="order-line[generate-id(.)=generate-id(key('groups',selling-code)[1])]">
<ns0:order-line-group>
<xsl:for-each select="key('groups',selling-code)">
<ns0:order-line>
<shipment
xmlファイルは現在のノードから解析され、構築されたキー<order-line
はその特定の出荷に対してのみノードを使用することを期待します。しかし、代わりに、ファイル内の<shipment
すべてのノードを含む3つのノードを取得<order-line
します。それで、キーが作成されるとき、xmlファイルは常にルートから解析されるように見えますか?そうですか?これを回避する方法はありますか?