xpath 的定位方法, 非常強大。 使用這種方法幾乎可以定位到頁面上的任意元素。
閱讀目錄
什麼是xpath
xpath 是XML Path的簡稱, 由於HTML文檔本身就是一個標準的XML頁面,所以我們可以使用Xpath 的用法來定位頁面元素。
xpath定位的缺點
xpath 這種定位方式, webdriver會將整個頁面的所有元素進行掃描以定位我們所需要的元素, 這是個非常費時的操作, 如果腳本中大量使用xpath做元素定位的話, 腳本的執行速度可能會稍慢
testXpath.html 代碼如下
<html><head><title>Test Xpath</title></head><body> <div id="div1"> <input name="div1input"></input> <a href="http://www.sogou.com">搜狗搜索</a> <img src="http://www.sogou.com/images/logo/new/sogou.png" href="http://www.sogou.com">搜狗圖片</img> <input type="button" value="查詢"></input> </div> <br /> <div name="div2"> <input name="div2iniput" /></input> <a href="http://www.baidu.com">百度搜索</a> <img src="http://www.baidu.comn/img/bdlogo.png" href="http:/www.baidu.com">百度圖片</img> </div></body></html>
絕對路徑定位方式
在被測試網頁中, 查找第一個div標籤中的按鈕
XPath的表達式
/html/body/div/input[@value="查詢"]WebElement button = driver.findElement(By.xpath("/html/body/div/input[@value='查詢']"));使用瀏覽器調試工具,可以直接獲取xpath語句
絕對路徑的缺點
1. 一旦頁面結構發生改變,改路徑也隨之失效,必須重新。 所以不推薦使用絕對路徑的寫法
絕對路徑和相對路徑的區別
絕對路徑以"/" 開頭, 讓xpath 從文檔的根節點開始解析
相對路徑以"//" 開頭, 讓xpath 從文檔的任何元素節點開始解析
相對路徑定位方式
在被測試網頁中,查找第一個div標籤中的按鈕
XPath的表達式
//input[@value="查詢"]WebElement button = driver.findElement(By.xpath("//input[@value='查詢']"));使用索引號定位
在被測試網頁中, 查找第二個div標籤中的"查詢"按鈕
//input[2] WebElement button = driver.findElement(By.xpath("//input[2]"));使用頁面屬性定位
定位被測試頁面中的第一個圖片元素
//img[@alt='div1-img1']WebElement button = driver.findElement(By.xpath("//img[@alt='div1-img1']"));模糊定位starts-with關鍵字
查找圖片alt屬性開始位置包含'div1'關鍵字的元素
//imag[starts-with(@alt,'div')]
模糊定位contains關鍵字
查找圖片alt屬性包含'g1'關鍵字的元素
//imag[contains(@alt,'g1')]
text() 函數文本定位
查找所有文本為"百度搜索" 的元素
driver.findElement(By.xpath("//*[text()='百度搜索']"));
查找所有文本為“搜索” 的超鏈接
driver.findElement(By.xpath("//a[contains(text(),'搜索')]"));
以上就是java selenium XPath 定位的資料整理,後續繼續整理相關資料,謝謝大家對本站的支持!