Andreas: Unerwünschte Elementknoten beim Kopieren

Beitrag lesen

Hallo ( spzieller Gruss an Thomas ;-) )

Ich möchte zwei XML Dokumente vergleichen und die fehlenden Werte vom anderen übernehmen. Leider habe ich Probleme mit dem Iterieren. Die Ergebnisknoten kommen leider mehrfach vor

Rauskommen soll folgendes :

<mitarbeiter id="4">
<nachname>Huber</nachname>
<info rating="ok" info-id="338">

<!-->aus dem zweiten XML Dokument übernommen<!-->
<vertrag nr="1">Verhandlung</vertrag>

<telefon>5524</telefon>
    <info rating="sehr gut" gewicht="95" grösse="1.84" statur="kräftig"/>
   </mitarbeiter>

usw....

Hier das Beispiel :

Quelldatei :

<?xml version="1.0" encoding="UTF-8"?>
<mb-datenbank>
 <abteilung>
  <name>
        IT-Abteilung
    </name>
  <angehoerige>
   <mitarbeiter id="5">
    <nachname>Meier</nachname>
    <info rating="gut" info-id="334">
     <vertrag>2 Jahre</vertrag>
    </info>
    <telefon>3421</telefon>
    <info rating="gut" gewicht="80" grösse="1.85" statur="normal"/>
   </mitarbeiter>
   <mitarbeiter id="4">
    <nachname>Huber
                   </nachname>
    <info rating="ok" info-id="338">
     </info>
    <telefon>5524</telefon>
    <info rating="sehr gut" gewicht="95" grösse="1.84" statur="kräftig"/>
   </mitarbeiter>
   <mitarbeiter id="7">
    <nachname>Hinkelstein</nachname>
    <info rating="ok" info-id="355">
   </info>
    <telefon>3456</telefon>
    <info rating="ok" gewicht="73" grösse="1.88" statur="schlank"/>
   </mitarbeiter>
   <mitarbeiter id="9">
    <nachname>Krause</nachname>
    <info rating="mangelhaft" info-id="364">>
    </info>
    <telefon>4556</telefon>
    <info rating="schlecht" gewicht="97" grösse="1.73" statur="stark untersetzt"/>
   </mitarbeiter>
  </angehoerige>
 </abteilung>
</mb-datenbank>

*******************************************

Hier das zweite XML Dokument, von welchem die jeweiligen Vertragsknoten kopiert wird :

Name des Dokuments : test1.xml

<?xml version="1.0" encoding="UTF-8"?>
<mb-datenbank>
 <abteilung>
  <name>
   Produktion
    </name>
  <angehoerige>
   <mitarbeiter id="5">
    <nachname>Winther</nachname>
    <info rating="gut" info-id="334">
     <vertrag>2 Jahre</vertrag>
    </info>
    <telefon>3421</telefon>
    <info rating="gut" gewicht="80" grösse="1.85" statur="normal"/>
   </mitarbeiter>
   <mitarbeiter id="4">
    <nachname>Heinz</nachname>
    <info rating="ok" info-id="338">
     <vertrag nr="1">Verhandlung</vertrag>
    </info>
    <telefon>5524</telefon>
    <info rating=" gut" gewicht="86" grösse="1.83" statur="normal"/>
   </mitarbeiter>
   <mitarbeiter id="7">
    <nachname>Kruse</nachname>
    <info rating="ok" info-id="355">
     <vertrag nr="2">Verhandlung</vertrag>
    </info>
    <telefon>3456</telefon>
    <info rating="ok" gewicht="125" grösse="1.88" statur="Bierbauch"/>
   </mitarbeiter>
   <mitarbeiter id="9">
    <nachname>Berger</nachname>
    <info rating="mangelhaft" info-id="364">
     <vertrag nr="3">Verhandlung</vertrag>
    </info>
    <telefon>4556</telefon>
    <info rating="ok" gewicht="73" grösse="1.83" statur="normal"/>
   </mitarbeiter>
  </angehoerige>
 </abteilung>
</mb-datenbank>

*************************************

Das XSL Stylesheet :

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output method="xml"/>
 <xsl:template match="@*|node()">
  xsl:copy
   <xsl:apply-templates select="@*|node()"/>
  </xsl:copy>
 </xsl:template>
 <xsl:template match="//info[@info-id]">
  xsl:copy
   <xsl:apply-templates select="@*|node()"/>
  </xsl:copy>
  <xsl:if test="not(vertrag)">
   <xsl:apply-templates select="document('test1.xml')//info[@info-id]/vertrag" mode="copy"/>
  </xsl:if>
 </xsl:template>
 <xsl:template match="@*|node()" mode="copy">
  xsl:copy
   <xsl:copy-of select="@*|node()"/>
   <xsl:apply-templates mode="copy"/>
  </xsl:copy>
 </xsl:template>
</xsl:stylesheet>