溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python自動(dòng)化中元素定位的方法有哪些

發(fā)布時(shí)間:2021-06-17 09:16:30 來源:億速云 閱讀:201 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了Python自動(dòng)化中元素定位的方法有哪些,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、find_element_by_id()

find_element_by_id()

1.從上面定位到的元素屬性中,可以看到有個(gè)id屬性:id=“kw”,這里可以通過它的id屬性定位到這個(gè)元素。

2.定位到搜索框后,用send_keys()方法,就可以輸入文本。

from selenium import webdriver
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
# 通過id定位百度輸入框,并輸入'python'
ss = driver.find_element_by_id('kw')
ss.send_keys('python')

Python自動(dòng)化中元素定位的方法有哪些

二、find_element_by_name()

find_element_by_name()

1.從上面定位到的元素屬性中,可以看到有個(gè)name屬性:name=“wd”,這里可以通過它的name屬性單位到這個(gè)元素。
說明:這里運(yùn)行后會(huì)報(bào)錯(cuò),說明這個(gè)搜索框的name屬性不是唯一的,無法通過name屬性直接定位到輸入框

from selenium import webdriver
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
# 通過name定位百度輸入框,并輸入'python'
ss = driver.find_element_by_name('wd')
ss.send_keys('python')

Python自動(dòng)化中元素定位的方法有哪些

三、find_element_by_class_name()

find_element_by_class_name()

1.從上面定位到的元素屬性中,可以看到有個(gè)class屬性:class=“s_ipt”,這里可以通過它的class屬性定位到這個(gè)元素。

from selenium import  webdriver
driver = webdriver.Firefox()
driver.get('http://www.baidu.com')
#通過class定位百度輸入框,并輸入'python'
driver.find_element_by_class_name('s_ipt').send_keys('python')

Python自動(dòng)化中元素定位的方法有哪些

四、find_element_by_tag_name()

find_element_by_tag_name()

1.從上面定位到的元素屬性中,可以看到每個(gè)元素都有tag(標(biāo)簽)屬性,如搜索框的標(biāo)簽屬性,就是最前面的input。

2.很明顯,在一個(gè)頁面中,相同的標(biāo)簽有很多,所以一般不用標(biāo)簽來定位。以下例子,僅供參考和理解,運(yùn)行肯定報(bào)錯(cuò)。

from selenium import webdriver
driver = webdriver.Firefox()
driver.get('http://www.baidu.com')
#通過tag(標(biāo)簽)定位百度輸入框,并輸入'python'
ss = driver.find_element_by_tag_name('input')
ss.send_keys('python')

Python自動(dòng)化中元素定位的方法有哪些

五、find_element_by_link_text()

1.定位百度頁面上"hao123"這個(gè)按鈕

Python自動(dòng)化中元素定位的方法有哪些

查看頁面元素:

<a class="mnav" target="_blank" href="http://www.hao123.com" rel="external nofollow" >hao123</a>

2.從元素屬性可以分析出,有個(gè)href = "http://www.hao123.com

說明它是個(gè)超鏈接,對(duì)于這種元素,可以用以下方法:

from selenium import webdriver
driver = webdriver.Chrome()

driver.get('http://www.baidu.com')
#通過tlink(超鏈接)定位百度輸入框,并點(diǎn)擊
driver.find_element_by_link_name('hao123').click()

六、find_element_by_partial_link_text()

1.有時(shí)候一個(gè)超鏈接它的字符串可能比較長,如果輸入全稱的話,會(huì)顯示很長,這時(shí)候可以用一模糊匹配方式,截取其中一部分字符串就可以了

2.如“hao123”,只需輸入“ao123”也可以定位到

from selenium import webdriver
driver = webdriver.Chrome()

driver.get('http://www.baidu.com')
#通過partial_link定位百度輸入框,并點(diǎn)擊(partial_link是一種模糊匹配的方式)
driver.find_element_by_partial_link_name('hao123').click()

七、find_element_by_xpath()

1.以上定位方式都是通過元素的某個(gè)屬性來定位的,如果一個(gè)元素它既沒有id、name、class屬性也不是超鏈接,這么辦呢?或者說它的屬性很多重復(fù)的。這個(gè)時(shí)候就可以用xpath解決。
2.xpath是一種路徑語言,跟上面的定位原理不太一樣,首先第一步要先學(xué)會(huì)查看一個(gè)元素的xpath。

  • 對(duì)于谷歌瀏覽器來說,有自己 的xpath解析工具:鼠標(biāo)移到需要查看的html源碼上,右擊

  • 選擇copy

  • copy xpath,就是源碼的xpath路徑

Python自動(dòng)化中元素定位的方法有哪些

from selenium import webdriver
driver = webdriver.Chrome()

driver.get('http://www.baidu.com')
#通過xpath地址定位百度輸入框,并點(diǎn)擊(xpath地址即為賦值過來的地址)
driver.find_element_by_xpath('//*[@id="s-top-left"]/a[2]').click()

八、find_element_by_css_selector()

1.css是另外一種語法,比xpath更為簡潔,但是不太好理解。這里先學(xué)會(huì)如何用工具查看,后續(xù)的教程再深入講解

  • 對(duì)于谷歌瀏覽器來說,同樣有自己 的css解析工具:鼠標(biāo)移到需要查看的html源碼上,右擊

  • 選擇copy

  • copy selector,就是源碼的css路徑

Python自動(dòng)化中元素定位的方法有哪些

from selenium import webdriver
driver = webdriver.Chrome()

driver.get('http://www.baidu.com')
#通過css地址定位百度輸入框,并點(diǎn)擊
driver.find_element_by_xpath('#s-top-left > a:nth-child(2)').click()

總結(jié):

Python自動(dòng)化中元素定位的方法有哪些

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Python自動(dòng)化中元素定位的方法有哪些”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI