position-Funktion (XPath)

Gibt die Position oder die Indexnummer des Knotens relativ zu allen ausgewählten Knoten in der Knotenliste zurück.

number position()

Hinweise

Die Position des Knotens ist 1-basiert. Damit gibt der erste Knoten die Position 1 zurück.

Beispiel

In diesem Beispiel werden die Auswirkungen der Verwendung der position()-Funktion veranschaulicht.

XML-Datei (position.xml)

<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="position.xsl"?>      
<test>
    <x a="a11">
      <x a="a21">
        <x a="a31">
          <y b="b31">y31</y>
          <y b="b32">y32</y>
        </x>
      </x>
    </x>
    <x a="a12">
      <x a="a22">
        <y b="b21">y21</y>
        <y b="b22">y22</y>
      </x>
    </x>
    <x a="a13">
      <y b="b11">y11</y>
      <y b="b12">y12</y>
    </x>
    <x a="a14">
      <y b="b01">y01</y>
      <y b="b02">y02</y>
    </x>
</test>

XSLT-Datei (position.xsl)

<?xml version='1.0'?>
<xsl:stylesheet 
     version="1.0"
     xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

  <xsl:output method="xml"   
              omit-xml-declaration="yes"/>

  <xsl:template match="/">
     <xsl:apply-templates select="//x"/>
  </xsl:template>


  <xsl:template match="*">
    <xsl:element name="{name()}">
        <xsl:apply-templates select="@*"/>
        <xsl:value-of select="position()"/>
    </xsl:element>\n  
  </xsl:template>

  <xsl:template match="@*">
     <xsl:attribute name="{name()}">
        <xsl:value-of select="."/>
     </xsl:attribute>
  </xsl:template>

</xsl:stylesheet>

ms256233.collapse_all(de-de,VS.120).gifAusgabe

Das oben genannte XSLT-Stylesheet ordnet bei Anwendung auf die XML-Quelldatei alle <x>-Elemente neuen <x>-Elementen zu, deren Inhalt ihre Position im Dokument angibt.

<x a="a11">1</x>
<x a="a21">2</x>
<x a="a31">3</x>
<x a="a12">4</x>
<x a="a22">5</x>
<x a="a13">6</x>
<x a="a14">7</x>

Zur Veranschaulichung der Abhängigkeit der position()-Funktion von dem Kontext, in dem sie ausgeführt wird, wird die folgende Vorlagenregel (aus der oben genannten XSLT-Datei) ersetzt:

<xsl:template match="/">
  <xsl:apply-templates select="//x"/>
</xsl:template>

Die Vorlagenregel wird durch die folgende Regel ersetzt:

<xsl:template match="/">
     <xsl:apply-templates select="//x[1]"/>
  </xsl:template>

Daraus ergibt sich folgendes Ergebnis:

<x a="a11">1</x>
<x a="a21">2</x>
<x a="a31">3</x>
<x a="a22">4</x>

Die Vorlagenregel kann jedoch auch durch die folgende Regel ersetzt werden:

<xsl:template match="/">
  <xsl:apply-templates select="//x[2]"/>
</xsl:template>

Dann lautet das Ergebnis wie folgt:

<x a="a12">1</x>                 

Siehe auch

Referenz

Referenz zu XML-Datentypen