1. 程式人生 > >【轉】Selenium-xpath詳解

【轉】Selenium-xpath詳解

input end tab UC 子元素 dom 絕對路徑 sele .class

1、XPATH是什麽

XPATH是一門在XML文檔中查找信息的語言,XPATH可用來在XML文檔中對元素和屬性進行遍歷,主流的瀏覽器都支持XPATH,因為HTML頁面在DOM中表示為XHTML文檔。
XPATH語言是基於XML文檔的樹結構,並提供了瀏覽樹的能力,通過多樣的標準來選擇節點。
Selenium WebDriver支持使用XPATH表達式來定位元素。
XPATH和CSS選擇器最重要的區別是XPATH可以向前和向後查詢DOM結構的元素,而CSS選擇器只能向前查詢,這意味著XPATH可以通過子元素來定位父元素!

2、XPATH使用方法

使用XPATH有如下幾種方法定位元素(相比CSS選擇器,方法稍微多一點):

a、通過絕對路徑定位元素(不推薦!)

WebElement ele = driver.findElement(By.xpath("html/body/div/form/input"));

b、通過相對路徑定位元素

WebElement ele = driver.findElement(By.xpath("//input"));

c、使用索引定位元素

WebElement ele = driver.findElement(By.xpath("//input[4]"));

d、使用XPATH及屬性值定位元素

WebElement ele = driver.findElement(By.xpath("//input[@id=‘fuck‘]"));
//其他方法(看字面意思應該能理解吧)
WebElement ele = driver.findElement(By.xpath("//input[@type=‘submit‘][@name=‘fuck‘]"));
WebElement ele = driver.findElement(By.xpath("//input[@type=‘submit‘ and @name=‘fuck‘]"));
WebElement ele = driver.findElement(By.xpath("//input[@type=‘submit‘ or @name=‘fuck‘]"));

e、使用XPATH及屬性名稱定位元素

//查找所有input標簽中含有type屬性的元素
WebElement ele = driver.findElement(By.xpath("//input[@type]"));

f、部分屬性值匹配(和CSS選擇器類似)

WebElement ele = driver.findElement(By.xpath("//input[start-with(@id,‘fuck‘)]"));//匹配id以fuck開頭的元素,id=‘fuckyou‘
WebElement ele = driver.findElement(By.xpath("//input[ends-with(@id,‘fuck‘)]"));//匹配id以fuck結尾的元素,id=‘youfuck‘
WebElement ele = driver.findElement(By.xpath("//input[contains(@id,‘fuck‘)]"));//匹配id中含有fuck的元素,id=‘youfuckyou‘

g、使用任意值來匹配屬性及元素

WebElement ele = driver.findElement(By.xpath("//input[@*=‘fuck‘]"));//匹配所有input元素中含有屬性的值為fuck的元素

h、使用XPATH軸來定位元素

//XPATH軸沒有實際經驗,所以本文不討論它。

元素定位總結

//註:本專題只介紹java版
//By id
WebElement ele = driver.findElement(By.id());
//By Name
WebElement ele = driver.findElement(By.id());
//By className
WebElement ele = driver.findElement(By.className());
//By tabName
WebElement ele = driver.findElement(By.tagName());
//By linkText
WebElement ele = driver.findElement(By.linkText());
//By partialLinkText
WebElement ele = driver.findElement(By.partialLinkText());//通過部分文本定位連接
//By cssSelector
WebElement ele = driver.findElement(By.cssSelector());
//By XPATH
WebElement ele = driver.findElement(By.xpath());

【轉】Selenium-xpath詳解