您好,我有两种不同的xml,我想合并它们,根据匹配的源和目标xml节点值从目标xml复制一个节点
像这样的第一个xml:
<PRODUCTS>
<PRODUCT>
<NAME>PRODUCT 1</NAME>
<MAINCATID>38</MAINCATID>
<SUBCATID>39</SUBCATID>
</PRODUCT>
</PRODUCTS>
第二个XML就是这样
<CATEGORIES>
<MAINCATEGORY>
<MAINCATID>38</MAINCATID>
<MAINCATNAME>CATEGORY 1</MAINCATNAME>
</MAINCATEGORY>
<MAINCATEGORY>
<MAINCATID>37</MAINCATID>
<MAINCATNAME>CATEGORY 2</MAINCATNAME>
</MAINCATEGORY>
<SUBCATEGORY>
<SUBCATID>39</SUBCATID>
<SUBCATNAME>SUB CATEGORY 1</SUBCATNAME>
</SUBCATEGORY>
<SUBCATEGORY>
<SUBCATID>40</SUBCATID>
<SUBCATNAME>SUB CATEGORY 2</SUBCATNAME>
</SUBCATEGORY>
</CATEGORIES>
我的结果xml应该像
<PRODUCTS>
<PRODUCT>
<NAME>PRODUCT 1</NAME>
<MAINCATID>38</MAINCATID>
<MAINCATNAME>CATEGORY 1</MAINCATNAME>
<SUBCATID>39</SUBCATID>
<SUBCATNAME>SUB CATEGORY 1</SUBCATNAME>
</PRODUCT>
</PRODUCTS>
有很多这样的节点。我想从第二个xml基于主要和子食物ID获得类别名称。
您能为这个XSLT转换提供帮助吗?
在XSLT 1.0中,使用密钥从另一个文档中查找数据有点尴尬,但是就性能和代码清晰度而言,它仍然是最好的方法,恕我直言。尝试:
XSLT 1.0
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<xsl:variable name="lookup-source" select="document('file2.xml')" />
<xsl:key name="MAINCATID" match="MAINCATNAME" use="../MAINCATID" />
<xsl:key name="SUBCATID" match="SUBCATNAME" use="../SUBCATID" />
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="MAINCATID | SUBCATID">
<xsl:copy-of select="."/>
<xsl:variable name="key-name" select="local-name()"/>
<xsl:variable name="key-value" select="."/>
<!-- switch context to the other file for the actual lookup -->
<xsl:for-each select="$lookup-source">
<xsl:copy-of select="key($key-name, $key-value)" />
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
我们在这里假设您的“第一个xml”文档正在处理中。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句