標籤:
Xpath這是非常強大。但對比是一個更複雜的技術,希望上面去部落格園特別想看看一些專業職位。下面是一些簡單Xpath的文法和樣本,給你參考
<?xml version="1.0" encoding="ISO-8859-1"?>
<catalog>
<cd country="USA">
<title>Empire Burlesque</title>
<artist>Bob Dylan</artist>
<price>10.90</price>
</cd>
<cd country="UK">
<title>Hide your heart</title>
<artist>Bonnie Tyler</artist>
<price>9.90</price>
</cd>
<cd country="USA">
<title>Greatest Hits</title>
<artist>Dolly Parton</artist>
<price>9.90</price>
</cd>
</catalog>
定位節點
XML是樹狀結構,類似檔案系統內資料夾的結構。XPath也類似檔案系統的路徑命名方式。只是XPath 是一種模式(Pattern)。能夠選出 XML檔案中,路徑符合某個模式的全部節點出來。比如要選catalog底下的cd中全部price元素能夠用:
/catalog/cd/price
假設XPath的開頭是一個斜線(/)代表這是絕對路徑。假設開頭是兩個斜線(//)表示檔案裡全部符合模式的元素都會被選出來。即使是處於樹中不同的層級也會被選出來。
下面的文法會選出檔案裡全部叫做cd的元素(在樹中的不論什麼層級都會被選出來):
//cd
選擇未知的元素
使用星號(Wildcards,*)能夠選擇未知的元素。以下這個文法會選出/catalog/cd 的全部子項目:
/catalog/cd/*
下面的文法會選出全部catalog的子項目中,包括有price作為子項目的元素。
/catalog/*/price
下面的文法會選出有兩層父節點,叫做price的全部元素。
/*/*/price
下面的文法會選擇出檔案裡的全部元素。
//*
要注意的是。想要存取不分層級的元素,XPath文法必須以兩個斜線開頭(//)。想要存取未知元素才用星號(*)。星號僅僅能代表未知名稱的元素,不能代表未知層級的元素。
選擇分支
使用中括弧能夠選擇分支。
下面的文法從catalog的子項目中取出第一個叫做cd的元素。
XPath的定義中沒有第0元素這樣的東西。
/catalog/cd[1]
下面文法選擇catalog中的最後一個cd元素:(XPathj並未定義 first() 這樣的函式喔,用上例的 [1]就能夠取出第一個元素。
/catalog/cd[last()]
下面文法選出含有price子項目的全部/catalog/cd元素。
/catalog/cd[price]
下面文法選出price元素的值等於10.90的全部/catalog/cd元素
/catalog/cd[price=10.90]
下面文法選出price元素的值等於10.90的全部/catalog/cd元素 的price元素
/catalog/cd[price=10.90]/price
選擇一個以上的路徑
使用Or運算元(|)就能夠選擇一個以上的路徑。比如:
/catalog/cd/title | catalog/cd/artist
選擇全部title以及artist元素
//title | //artist
選擇全部title以及artist以及price元素
//title | //artist | //price
選擇屬性
在XPath中,除了選擇元素以外。也能夠選擇屬性。
屬性都是以@開頭。比如選擇檔案裡全部叫做country的屬性:
//@country
選擇全部含有country這個屬性的cd元素:
//cd[@country]
下面文法選擇出含有屬性的全部cd元素
//cd[@*]
下面文法選擇出country屬性值為UK的cd元素
//cd[@country=‘UK‘]
針對多個屬性的尋找:
Books/book[@author=‘John‘ and @year=‘2009‘ and @language=‘En‘]
著作權聲明:本文部落格原創文章,部落格,未經同意,不得轉載。
C#使用xpath找到一個節點