selenium xpath定位方式


1. 絕對定位:
   此方法最為簡單,具體格式為
          xxx.find_element_by_xpath("絕對路徑")
    具體例子:
         xxx.find_element_by_xpath("/html/body/div[x]/form/input") x 代表第x個 div標簽,注意,索引從1開始而不是0
        此方法缺點顯而易見,當頁面元素位置發生改變時,都需要修改,因此,並不推薦使用。
2.相對路徑:
相對路徑,以‘//’開頭,具體格式為
 xxx.find_element_by_xpath("//標簽")
具體例子:
xxx.find_element_by_xpath("//input[x]") 定位第x個input標簽,[x]可以省略,默認為第一個
  相對路徑的長度和開始位置並不受限制,也可以采取以下方法
xxx.find_element_by_xpath("//div[x]/form[x]/input[x]"), [x]依然是可以省略的  
("//*[@id='J_login_form']/dl/dt/input[@id='J_password']"
3.標簽屬性定位:
           3.1標簽屬性定位,相對比較簡單,也要求屬性能夠定位到唯一一個元素,如果存在多個相同條件的標簽,默認只是第一個,具體格式
      xxx.find_element_by_xpath("//標簽[@屬性==‘屬性值’]")
屬性判斷條件:最常見為id,name,class等等,目前屬性的類別沒有特殊限制,只要能夠唯一標識一個元素都是可以的
具體例子
       xxx.find_element_by_xpath("//a[@href='/industryMall/hall/industryIndex.ht']")
       xxx.find_element_by_xpath("//input[@value='確定']")
       xxx.find_element_by_xpath("//div[@class = 'submit']/input")
          當某個屬性不足以唯一區別某一個元素時,也可以采取多個條件組合的方式,具體例子
        xxx..find_element_by_xpath("//input[@type='name' and @name='kw1']")
       3.2 當標簽屬性很少,不足以唯一區別元素時,但是標簽中間中間存在唯一的文本值,也可以定位,其具體格式
       xxx.find_element_by_xpath("//標簽[contains(text(),'文本值')]") 
     具體例子:
        xxx.find_element_by_xpath("//iunpt[contains(text(),'型號:')]")  
       注意:盡量在html中復制此段文本,避免因為肉眼無法分辨的字符導致定位失敗
      3.3 其他的屬性值如果太長,也可以采取模糊方法定位,直接上示例
 
       xxx.find_element_by_xpath(“//a[contains(@href, ‘logout’)]”)
  3.4 XPath 關於網頁中的動態屬性的定位,例如,ASP.NET應用程序中動態生成id屬性值,可以有以下四種方法:
      a.starts-with 例子: input[starts-with(@id,'ctrl')] 解析:匹配以ctrl開始的屬性值
      b.ends-with 例子:input[ends-with(@id,'_userName')] 解析:匹配以userName結尾的屬性值
      c.contains() 例子:Input[contains(@id,'userName')] 解析:匹配含有userName屬性值
當然,如果上面的單一方法不能完成定位,也可以采取組合式定位 類似("//input[@id='kw1']//input[start-with(@id,'nice']/div[1]/form[3])
 
以上是普通的情況,存在可以定位的屬性,當某個元素的各個屬性及其組合都不足以定位時,我們可以利用其兄弟節點或者父節點等各種可以定位的元素進行定位,先看看xpath中支持的方法:
     1、child 選取當前節點的所有子元素
     2、parent 選取當前節點的父節點
     3、descendant選取當前節點的所有后代元素(子、孫等)
     4、ancestor 選取當前節點的所有先輩(父、祖父等)
     5、descendant-or-self選取當前節點的所有后代元素(子、孫等)以及當前節點本身
     6、ancestor-or-self 選取當前節點的所有先輩(父、祖父等)以及當前節點本身
     7、preceding-sibling選取當前節點之前的所有同級節點
     8、following-sibling選取當前節點之后的所有同級節點
     9、preceding 選取文檔中當前節點的開始標簽之前的所有節點
    10、following 選取文檔中當前節點的結束標簽之后的所有節點
    11、self 選取當前節點
    12、attribute 選取當前節點的所有屬性
    13、namespace選取當前節點的所有命名空間節點
上圖實例,需要點擊訂單號為17051915200001的發貨按鈕,這時候不能直接定位到發貨按鈕,而是先要定位到訂單號元素,再定位他的兄弟節點。參照上圖,我們首先定位到td標簽中包含訂單號的td元素,然后選擇其之后的同級節點,following-sibling,我們要找的元素在后面的第8個td標簽下,因此定位可以寫名為下面的格式
Xxx.find_element_by_xpath("//td[contains(text(),’17051915200001’)]/following-sibling::td[8]/a[@class='link']")  
preceding-sibling 情況類似,但是所有元素的排列順序是相反的(和following-sibling相反),如圖:
 
 
--------------------- 
原文:https://blog.csdn.net/huiseqiutian/article/details/73739707 
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM