XPath 範例
這個主題會檢閱整個 XPath 參考中出現的語法範例。它們都是以 XPath 的 XML 檔範例語法 (inventory.xml) 為基礎。如需在測試檔中使用 XPath 運算式的範例,請參閱這個主題結尾的<聯集範例 ( | )>。
./author
|
目前內容中的所有 <author> 項目。請注意,其等同於下一資料列的運算式。 |
author
|
目前內容中的所有 <author> 項目。 |
first.name
|
目前內容中的所有 <first.name> 項目。 |
/bookstore
|
這份文件的文件項目 (<bookstore> )。 |
//author
|
文件中的所有 <author> 項目。 |
book[/bookstore/@specialty=@style]
|
所有 <book> 項目,其 style 屬性值等於文件根上之 <bookstore> 項目的 specialty 屬性值。 |
author/first-name
|
當做 <author> 項目子系的所有 <first-name> 項目。 |
bookstore//title
|
位於 <bookstore> 項目一或多層深的所有 <title> 項目 (任意子代)。請注意,其不同於下一資料列的運算式。 |
bookstore/*/title
|
當做 <bookstore> 項目子系的所有 <title> 項目。 |
bookstore//book/excerpt//emph
|
所有 <emph> 項目,其位於 <book> 項目的 <excerpt> 子系之任何位置,以及 <bookstore> 項目的任何位置。 |
.//title
|
位於目前內容中一或多層深的所有 <title> 項目。請注意,唯有在此情況下,才需要使用句點標記法。 |
author/*
|
當做 <author> 項目子系的所有項目。 |
book/*/last-name
|
當做 <book> 項目子系的所有 <last-name> 項目。 |
*/*
|
目前內容的所有孫代項目。 |
*[@specialty]
|
含 specialty 屬性的所有項目。 |
@style
|
目前內容的 style 屬性。 |
price/@exchange
|
目前內容中所有 <price> 項目的 exchange 屬性。 |
price/@exchange/total
|
傳回空節點集,因為屬性不含項目子系。XML 路徑語言 (XPath) 文法允許這個運算式,但其效果不大。 |
book[@style]
|
內含目前內容之 style 屬性的所有 <book> 項目。 |
book/@style
|
目前內容之所有 <book> 項目的 style 屬性。 |
@*
|
目前項目內容的所有屬性。 |
./first-name
|
目前內容節點中的所有 <first-name> 項目。請注意,其等同於下一個資料列的運算式。 |
first-name
|
目前內容節點中的所有 <first-name> 項目。 |
author[1]
|
目前內容節點中的第一個 <author> 項目。 |
author[first-name][3]
|
具有 <first-name> 子系的第三個 <author> 項目。 |
my:book
|
my 命名空間的 <book> 項目。
|
my:*
|
my 命名空間的所有項目。
|
@my:*
|
my 命名空間的所有屬性 (不含 my 命名空間項目上不合格的屬性)。
|
請注意,索引與父代是相對的。請參考下列資料:
<x>
<y/>
<y/>
</x>
<x>
<y/>
<y/>
</x>
x/y[1]
|
每一個 <x> 的第一個 <y> 子系。其等同於下一資料列的運算式。 |
x/y[position() = 1]
|
每一個 <x> 的第一個 <y> 子系。 |
(x/y)[1]
|
來自 <x> 項目整組 <y> 子系的第一個 <y> 。 |
x[1]/y[2]
|
第一個 <x> 的第二個 <y> 子系。 |
如需其他範例,請參考<XPath 的 XML 檔範例>。
book[last()]
|
目前內容節點的最後一個 <book> 項目。 |
book/author[last()]
|
目前內容節點中每一個 <book> 項目的最後一個 <author> 子系。 |
(book/author)[last()]
|
最後一個 <author> 項目,其來自目前內容節點之 <book> 項目的整組 <author> 子系。 |
book[excerpt]
|
至少包含一個 <excerpt> 項目子系的所有 <book> 項目。 |
book[excerpt]/title
|
當做 <book> 項目子系,且至少包含一個 <excerpt> 項目子系的所有 <title> 項目。 |
book[excerpt]/author[degree]
|
至少包含一個 <degree> 項目子系,且當做至少包含一個 <excerpt> 項目之 <book> 項目子系的所有 <author> 項目。 |
book[author/degree]
|
包含 <author> 子系 (至少包含一個 <degree> 子系) 的所有 <book> 項目。 |
author[degree][award]
|
至少包含一個 <degree> 項目子系和至少一個 <award> 項目子系的所有 <author> 項目。 |
author[degree and award]
|
至少包含一個 <degree> 項目子系和至少一個 <award> 項目子系的所有 <author> 項目。 |
author[(degree or award) and publication]
|
至少包含一個 <degree> 或 <award> 和至少一個 <publication> 當做子系的所有 <author> 項目。 |
author[degree and not(publication)]
|
至少包含一個 <degree> 項目子系,且不包含 <publication> 項目子系的所有 <author> 項目。 |
author[not(degree or award) and publication]
|
至少包含一個 <publication> 項目子系,且不包含 <degree> 也不包含 <award> 項目子系的所有 <author> 項目。 |
author[last-name = "Bob"]
|
至少包含一個 <last-name> 項目子系 (包含值 Bob ) 的所有 <author> 項目。 |
author[last-name[1] = "Bob"]
|
其中第一個 <last-name> 子項目之值為 Bob 的所有 <author> 項目。請注意,其等同於下一個資料列的運算式。 |
author[last-name [position()=1]= "Bob"]
|
其中第一個 <last-name> 子項目之值為 Bob 的所有 <author> 項目。 |
degree[@from != "Harvard"]
|
其中 from 屬性不等於 "Harvard" 的所有 <degree> 項目。 |
author[. = "Matthew Bob"]
|
其值為 Matthew Bob 的所有 <author> 項目。 |
author[last-name = "Bob" and ../price > 50]
|
內含 <last-name> 子項目 (其值為 Bob ) 和 <price> 同層級項目 (其值大於 50) 的所有 <author> 項目。 |
book[position() <= 3]
|
前三本書 (1、2、3)。 |
author[not(last-name = "Bob")]
|
不包含 <last-name> 子項目 (包含值 Bob ) 的所有 <author> 項目。 |
author[first-name = "Bob"]
|
至少包含一個 <first-name> 子系 (包含值 Bob ) 的所有 <author> 項目。 |
author[* = "Bob"]
|
所有包含值為 Bob 之任何子項目的所有 author 項目。 |
author[last-name = "Bob" and first-name = "Joe"]
|
內含 <last-name> 子項目 (含值 Bob ) 和 <first-name> 子項目 (其值為 Joe ) 的所有 <author> 項目。 |
price[@intl = "Canada"]
|
內容節點中 intl 屬性等於 "Canada" 的所有 <price> 項目。 |
degree[position() < 3]
|
內容節點子系的前兩個 <degree> 項目。 |
p/text()[2]
|
內容節點中每個 <p> 項目的第二個文字節點。 |
ancestor::book[1]
|
內容節點中最接近的 <book> 上階。 |
ancestor::book[author][1]
|
內容節點的最接近 <book> 上階,且這個 <book> 項目將 <author> 項目當做子系。 |
ancestor::author[parent::book][1]
|
目前內容中最接近的 <author> 上階,並且這個 <author> 項目是 <book> 項目的子系。 |
聯集範例 ( | )
為了展示聯集運算,我們使用下列 XPath 運算式:
x | y/x
在下列 XML 檔中,選取其值為 green 或 blue 的所有 <x> 項目:
XML 檔 (data1.xml)
XSLT 檔 (union.xsl)
格式化輸出
green,blue,blue,green
處理器輸出
<?xml version="1.0" encoding="UTF-16"?>green,blue,blue,green
另請參閱
參考
位置路徑範例
概念
XPath 的 XML 檔範例語法 (inventory.xml)