<xsl:value-of select='$updates/updates/elem [@xpath="/employee/address/country" ]/@xvalue' />
which should return the string "USA".
cknell@xxxxxxxxxx - email
From: Jianyu Lai <jlai@xxxxxxxx>
Sent: Tue, 1 Feb 2005 08:57:59 -0800
To: "'xsl-list@xxxxxxxxxxxxxxxxxxxxxx'" <xsl-list@xxxxxxxxxxxxxxxxxxxxxx>
Subject: [xsl] Merging two xml documents using xslt
I'm rather new to XSL. I am struggling trying to come up with an xslt to
solve the following problem:
First I have the source xml that looks like this:
I have another xml (updates.xml) that contains information about how to
update the above source. Notice that this updates.xml is dynamically
generated, and its contents vary.
<elem xpath="/employee/address/country" xvalue="USA" />
<elem xpath="/employee/name/first" xvalue="Bill" />
I want to write an xslt that reads information from updates.xml, and updates
source.xml based on these criteria:
- if xpath in updates.xml exist in source.xml, replace source xml node with
- otherwise, create xml node in source(recursively if necessary), with
xvalue defined in updates.xml;
Basically here is the result xml that I need:
Is this something that can be done by xslt? If so, could any one shed some
light on this? Your help is greatly appreciated.