XPath- syntaxis
XPath gebruikt padexpressies om knooppunten of knooppuntsets in een XML-document te selecteren. Het knooppunt wordt geselecteerd door een pad of stappen te volgen.
Het XML-voorbeelddocument
We zullen het volgende XML-document gebruiken in de onderstaande voorbeelden.
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book>
<title lang="en">Harry Potter</title>
<price>29.99</price>
</book>
<book>
<title lang="en">Learning XML</title>
<price>39.95</price>
</book>
</bookstore>
Knooppunten selecteren
XPath gebruikt padexpressies om knooppunten in een XML-document te selecteren. Het knooppunt wordt geselecteerd door een pad of stappen te volgen. De handigste paduitdrukkingen worden hieronder vermeld:
Expression | Description |
---|---|
nodename | Selects all nodes with the name "nodename" |
/ | Selects from the root node |
// | Selects nodes in the document from the current node that match the selection no matter where they are |
. | Selects the current node |
.. | Selects the parent of the current node |
@ | Selects attributes |
In de onderstaande tabel hebben we enkele paduitdrukkingen en het resultaat van de uitdrukkingen opgesomd:
Path Expression | Result |
---|---|
bookstore | Selects all nodes with the name "bookstore" |
/bookstore | Selects the root element bookstore Note: If the path starts with a slash ( / ) it always represents an absolute path to an element! |
bookstore/book | Selects all book elements that are children of bookstore |
//book | Selects all book elements no matter where they are in the document |
bookstore//book | Selects all book elements that are descendant of the bookstore element, no matter where they are under the bookstore element |
//@lang | Selects all attributes that are named lang |
predikaten
Predikaten worden gebruikt om een specifiek knooppunt te vinden of een knooppunt dat een specifieke waarde bevat.
Predikaten staan altijd tussen vierkante haken.
In de onderstaande tabel hebben we enkele paduitdrukkingen met predikaten en het resultaat van de uitdrukkingen opgesomd:
Path Expression | Result |
---|---|
/bookstore/book[1] | Selects the first book element that is the child of the bookstore element.
Note: In IE 5,6,7,8,9 first node is[0], but according to W3C, it is [1]. To solve this problem in IE, set the SelectionLanguage to XPath: In JavaScript: xml.setProperty("SelectionLanguage","XPath"); |
/bookstore/book[last()] | Selects the last book element that is the child of the bookstore element |
/bookstore/book[last()-1] | Selects the last but one book element that is the child of the bookstore element |
/bookstore/book[position()<3] | Selects the first two book elements that are children of the bookstore element |
//title[@lang] | Selects all the title elements that have an attribute named lang |
//title[@lang='en'] | Selects all the title elements that have a "lang" attribute with a value of "en" |
/bookstore/book[price>35.00] | Selects all the book elements of the bookstore element that have a price element with a value greater than 35.00 |
/bookstore/book[price>35.00]/title | Selects all the title elements of the book elements of the bookstore element that have a price element with a value greater than 35.00 |
Onbekende knooppunten selecteren
XPath-jokertekens kunnen worden gebruikt om onbekende XML-knooppunten te selecteren.
Wildcard | Description |
---|---|
* | Matches any element node |
@* | Matches any attribute node |
node() | Matches any node of any kind |
In de onderstaande tabel hebben we enkele paduitdrukkingen en het resultaat van de uitdrukkingen opgesomd:
Path Expression | Result |
---|---|
/bookstore/* | Selects all the child element nodes of the bookstore element |
//* | Selects all elements in the document |
//title[@*] | Selects all title elements which have at least one attribute of any kind |
Meerdere paden selecteren
Door de | . te gebruiken operator in een XPath-expressie kunt u verschillende paden selecteren.
In de onderstaande tabel hebben we enkele paduitdrukkingen en het resultaat van de uitdrukkingen opgesomd:
Path Expression | Result |
---|---|
//book/title | //book/price | Selects all the title AND price elements of all book elements |
//title | //price | Selects all the title AND price elements in the document |
/bookstore/book/title | //price | Selects all the title elements of the book element of the bookstore element AND all the price elements in the document |