Hi fredyw ,
You can use xslt to do this.
See my sample,
xmlfile73.xml :
<staffs>
<staff order ="1">
<name>wang </name>
<age>27 </age>
</staff>
<staff order ="2">
<name>Li </name>
<age>24 </age>
</staff>
<staff order ="3">
<name>Q1 </name>
<age>29 </age>
</staff>
</staffs>
xmlfile74.xml :
<staffs>
<staff order ="1">
<name>wang </name>
<Money>100 </Money>
</staff>
<staff order ="2">
<name>Li </name>
<Money>200 </Money>
</staff>
<staff order ="3">
<name>Q1 </name>
<Money>400 </Money>
</staff>
</staffs>
xslt file:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" omit-xml-declaration="yes"/>
<xsl:variable name="file2" select="document('XMLFile74.xml')"/>
<xsl:template match="/">
<staffs>
<xsl:for-each select="/staffs/staff">
<xsl:variable name="CurrentOrder">
<xsl:value-of select ="attribute::order" />
</xsl:variable>
<staff>
<xsl:attribute name="order">
<xsl:value-of select="@order" />
</xsl:attribute>
<xsl:copy-of select="name" />
<xsl:copy-of select="age" />
<xsl:copy-of select="$file2/staffs/staff[@order=$CurrentOrder]/Money" />
</staff>
</xsl:for-each>
</staffs>
</xsl:template>
</xsl:stylesheet>