2 つの xml ファイルがあります。1 つは実際のデータで、もう 1 つはデータから抽出したいノードのキーのリストです。多くの検索とテストを行った後、助けを求めたいと思いました。望む結果が得られません。
データファイル:
<?xml version="1.0" encoding="UTF-8"?>
<Items>
<Item>
<ItemKey>12345</ItemKey>
<Name>Apple></Name>
<Attribute>Red</Attribute>
</Item>
<Item>
<ItemKey>67890</ItemKey>
<Name>Orange</Name>
<Attribute>Orange</Attribute>
</Item>
<Item>
<ItemKey>12346</ItemKey>
<Name>Grape</Name>
<Attribute>Purple</Attribute>
</Item>
<Item>
<ItemKey>67891</ItemKey>
<Name>Pear</Name>
<Attribute>Yellow</Attribute>
</Item>
</Items>
フィルタ ファイル:
<?xml version="1.0" encoding="UTF-8"?>
<Items>
<Item>
<ItemKey>12345</ItemKey>
</Item>
<Item>
<ItemKey>12346</ItemKey>
</Item>
</Items>
データ ファイルを変換して、フィルタ ファイルの ItemKey に一致するサブノードとサブノードのみを抽出しようとしています。私が見たいくつかの例を使用してみましたが、次の xml を使用しても成功しませんでした。
<?xml version="1.0"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:variable name="filter" select="document('Filter.xml')/Item/*"/>
<xsl:template match="/">
<xsl:for-each select="Items/Item">
<xsl:choose>
<xsl:when test="$filter/Item/ItemKey[contains(., ./ItemKey)]">
<xsl:call-template name="Filtered"/>
</xsl:when>
</xsl:choose>
</xsl:for-each>
</xsl:template>
<xsl:template name="Filtered">
<xsl:text>	"</xsl:text>
<xsl:value-of select="ItemKey" />, <xsl:value-of select="Name"/>
<xsl:text>",
</xsl:text>
</xsl:template>
</xsl:stylesheet>
ご覧のとおり、テキストに変換したいので、必要なノードを取得していることがわかったら、適切にフォーマットします。ご協力いただきありがとうございます。