I need to merge two similar xml files, but only records which match on common tags, e.g.<type>
in the following example:
file1.xml is
<node>
<type>a</type>
<name>joe</name>
</node>
<node>
<type>b</type>
<name>sam</name>
</node>
file2.xml is
<node>
<type>a</type>
<name>jill</name>
</node>
so that I have an output of
<node>
<type>a</type>
<name>jill</name>
<name>joe</name>
</node>
<node>
<type>b</type>
<name>sam</name>
</node>
What are the basics of doing this, in xsl? Many thanks.
I thought it worth adding some extra info I've learned while doing this, in case it's of use to any other beginners. I've changed my test code names so that they aren't potentially confused with some of the terms used in the xsl. I've no idea if it's the best or most efficient way of doing things, but it works (with a few caveats!).
I wanted to keep the "info" node, and the original code lost it. Coding a separate match template keeps it in the output. Also, the way I coded it, this node is only kept if it is in the input file (x1). If it's in the (x2) file, then it doesn't get kept. This has to be with the way I've written the iterations. Ideally, I'd like to keep it from either input file, but haven't worked out how to do that yet. Also, I'd like to have the option of passing the filename x2 as a parameter, via msxsl, rather than have it hard coded. There surely must be a way of doing this, but I haven't managed to track it down yet.
xsl file:
So, using the msxls command:
Gives the following results with the data below:
file x1.xml:
file x2.xml:
out.xml:
One way is to pass second xml as a parameter,
Second easier way is to concatenate both xmls under the one root element to
and then do merge it using 2
This stylesheet:
With this input (wellformed):
Output: