I have two files with related information that is gathered separately. When each processor is done gathering the xml data in the same format, how can I merge the two xml files using XSLT?
For example:
AllSets_Names.xml
<Sets>
<Set id="1">
<SetName>World Champ Decks 1999</SetName>
</Set>
<Set id="2">
<SetName>World Champ Decks 1999</SetName>
</Set>
<Set id="3">
<SetName>World Champ Decks 1999</SetName>
</Set>
<Set id="4">
<SetName>World Champ Decks 1999</SetName>
</Set>
<Set id="5">
<SetName>World Champ Decks 1999</SetName>
</Set>
</Sets>
AllSets_ShortNames.xml
<Sets>
<Set id="1">
<SetShortName>W99</SetShortName>
</Set>
<Set id="2">
<SetShortName>W00</SetShortName>
</Set>
<Set id="3">
<SetShortName/>
</Set>
<Set id="4">
<SetShortName>WD2</SetShortName>
</Set>
<Set id="5">
<SetShortName>WD3</SetShortName>
</Set>
</Sets>
Desired Output: AllSets_NamesAndShortNames.xml
<Sets>
<Set id="1">
<SetName>World Champ Decks 1999</SetName>
<SetShortName>W99</SetShortName>
</Set>
<Set id="2">
<SetName>World Champ Decks 1999</SetName>
<SetShortName>W00</SetShortName>
</Set>
<Set id="3">
<SetName>World Champ Decks 1999</SetName>
<SetShortName/>
</Set>
<Set id="4">
<SetName>World Champ Decks 1999</SetName>
<SetShortName>WD2</SetShortName>
</Set>
<Set id="5">
<SetName>World Champ Decks 1999</SetName>
<SetShortName>WD3</SetShortName>
</Set>
</Sets>
A good way to do this is using grouping:
<xsl:template name="main">
<Sets>
<xsl:for-each-group
select="document(('Names.xml','ShortNames.xml'))/Sets/Set"
group-by="@id">
<Set>
<xsl:copy-of select="current-group()/(@*, *)"/>
</Set>
</xsl:for-each-group>
</Sets>
</xsl:template>
You could do it this way:
XSLT 2.0
<xsl:stylesheet version="2.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:param name="short-names-path" select="'AllSets_ShortNames.xml'"/>
<xsl:key name="set-by-id" match="Set" use="@id" />
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="Set">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
<xsl:copy-of select="key('set-by-id', @id, document($short-names-path))/SetShortName"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
This assumes you are processing the AllSets_Names.xml
document and passing the path to AllSets_ShortNames.xml
as a parameter.
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.