XPath語法概述

2021-10-14 04:18:37 字數 4213 閱讀 9835

xpath節點

xpath語法

xpath axes(軸)

xpath運算子

相關擴充套件

xpath 是一門在 xml 文件中查詢資訊的語言。xpath 用於在 xml 文件中通過元素和屬性進行導航。

在學習xpath之前,應該對下面的知識有基本了解:

在xpath中,有七種型別的節點:

<?xml version="1.0" encoding="iso-8859-1"?>

harry potter

j k. rowling

2005

29.99

上面文件中的節點:

(文件節點)

j k. rowling (元素節點)

lang="en" (屬性節點)

j k. rowling

"en"

xpath使用路徑表示式來選取xml文件中的節點或節點集。節點是通過沿著路徑(path)或者步(steps)來選取的。

以下面xml文件為例:

<?xml version="1.0" encoding="iso-8859-1"?>

harry potter

29.99

learning xml

39.95

以下是比較常用的路徑表示式:

表示式描述

nodename

選取此節點的所有子節點

/從根節點擊取

//從匹配選擇的當前節點擊擇文件中的節點,而不考慮它們的位置。

.選取當前節點

. .選取當前節點的父節點

@選取屬性

表示式描述bookstore

選取 bookstore 元素的所有子節點。

/bookstore

選取根元素 bookstore。注釋:假如路徑起始於正斜槓( / ),則此路徑始終代表到某元素的絕對路徑!

bookstore/book

選取屬於 bookstore 的子元素的所有 book 元素。

//book

選取所有 book 子元素,而不管它們在文件中的位置。

bookstore//book

選擇屬於 bookstore 元素的後代的所有 book 元素,而不管它們位於 bookstore 之下的什麼位置。

//@lang

選取名為 lang 的所有屬性。

表示式描述/bookstore/book[1]

選取屬於 bookstore 子元素的第乙個 book 元素。

/bookstore/book[last()]

選取屬於 bookstore 子元素的最後乙個 book 元素。

/bookstore/book[last()-1]

選取屬於 bookstore 子元素的倒數第二個 book 元素。

/bookstore/book[position()< 3]

選取最前面的兩個屬於 bookstore 元素的子元素的 book 元素。

//title[@lang]

選取所有擁有名為 lang 的屬性的 title 元素。

//title[@lang=『eng』]

選取所有 title 元素,且這些元素擁有值為 eng 的 lang 屬性。

/bookstore/book[price>35.00]

選取 bookstore 元素的所有 book 元素,且其中的 price 元素的值須大於 35.00。

/bookstore/book[price>35.00]/title

選取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值須大於 35.00。

xpath 萬用字元可用來選取未知的 xml 元素。

萬用字元描述

*匹配任何元素節點。

@*匹配任何屬性節點。

node()

匹配任何型別的節點。

路徑表示式

結果/bookstore/*

選取 bookstore 元素的所有子元素。

//*選取文件中的所有元素。

//title[@*]

選取所有帶有屬性的 title 元素。

通過在路徑表示式中使用「|」運算子,您可以選取若干個路徑。

路徑表示式

結果//book/title | //book/price

選取 book 元素的所有 title 和 price 元素。

/bookstore/book/title | //price

選取屬於 bookstore 元素的 book 元素的所有 title 元素,以及文件中所有的 price 元素。

軸可定義相對於當前節點的節點集

軸名稱結果ancestor

選取當前節點的所有先輩(父、祖父等)。

ancestor-or-self

選取當前節點的所有先輩(父、祖父等)以及當前節點本身。

attribute

選取當前節點的所有屬性。

child

選取當前節點的所有子元素。

descendant

選取當前節點的所有後代元素(子、孫等)。

descendant-or-self

選取當前節點的所有後代元素(子、孫等)以及當前節點本身。

following

選取文件中當前節點的結束標籤之後的所有節點。

namespace

選取當前節點的所有命名空間節點。

parent

選取當前節點的父節點。

preceding

選取文件中當前節點的開始標籤之前的所有節點。

preceding-sibling

選取當前節點之前的所有同級節點。

self

選取當前節點。

位置路徑可以是絕對的,也可以是相對的。

絕對路徑起始於正斜槓( / ),而相對路徑不會這樣。在兩種情況中,位置路徑均包括乙個或多個步,每個步均被斜槓分割:

/step/step/...
step/step/...
每個步均根據當前節點集之中的節點來進行計算。

步(step)包括:

的語法:

軸名稱::節點測試[謂語]
舉例如下:

語法描述

child::book

選取所有屬於當前節點的子元素的 book 節點。

attribute::lang

選取當前節點的 lang 屬性。

child:: *

選取當前節點的所有子元素。

attribute:: *

選取當前節點的所有屬性。

child::text()

選取當前節點的所有文字子節點。

child::node()

選取當前節點的所有子節點。

descendant::book

選取當前節點的所有 book元素 後代。

ancestor::book

選擇當前節點的所有 book 元素先輩。

ancestor-or-self::book

選取當前節點的所有 book 先輩以及當前節點(如果此節點是 book 節點)

child:: */child::price

選取當前節點的所有 price 孫節點。

下面列出了可用在xpath表示式中的運算子:

運算子描述

|計算兩個節點集合+加法

-減法*乘法

div除法=等於

!=不等於

<

小於<=

小於等於

>

大於》=

大於等於or或

and且

mod求餘數

xslt 是針對 xml 檔案的樣式表語言。

通過 xslt,您可以把 xml 檔案轉換為其他的格式,比如 xhtml。

xquery 和 xml 資料查詢有關。

xquery 被設計用來查詢任何可作為 xml 形態呈現的資料,包括資料庫。

xlink 和 xpointer 定義了在 xml 文件中建立超級鏈結的標準方法。

如果希望學習更多有關 xlink 和 xpointer 的知識,可參考《xlink 教程和 xpointer教程》。

XPath 簡單語法

xpath 是xml的查詢語言,和sql的角色很類似。以下面xml為例,介紹xpath 的語法。empire burlesque bob dylan 10.90 hide your heart bonnie tyler 9.90 greatest hits dolly parton 9.90 定位節...

XPath查詢語法

xpath 使用路徑表示式在 xml 文件中選取節點。節點是通過沿著路徑或者 step 來選取的。表示式描述 nodename 選取此節點的所有子節點 從根節點擊取 從匹配選擇的當前節點擊擇文件中的節點,而不考慮它們的位置 選取當前節點 選取當前節點的父節點 選取屬性 在下面的 中,我們已列出了一些...

XPath 簡單語法

xpath 是xml的查詢語言,和sql的角色很類似。以下面xml為例,介紹xpath 的語法。empire burlesque bob dylan 10.90 hide your heart bonnie tyler 9.90 greatest hits dolly parton 9.90 定位節...