亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python自動(dòng)化八大定位元素講解

 更新時(shí)間:2021年07月08日 16:28:22   作者:巭孬嫑惹佳樂(lè)~  
這篇文章主要介紹了python自動(dòng)化八大定位元素講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是本文的詳細(xì)內(nèi)容,需要的朋友可以參考下

一、find_element_by_id()

find_element_by_id()
1.從上面定位到的元素屬性中,可以看到有個(gè)id屬性:id=“kw”,這里可以通過(guò)它的id屬性定位到這個(gè)元素。
2.定位到搜索框后,用send_keys()方法,就可以輸入文本。

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

在這里插入圖片描述

二、find_element_by_name()

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

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

在這里插入圖片描述

三、find_element_by_class_name()

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

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

在這里插入圖片描述

四、find_element_by_tag_name()

find_element_by_tag_name()
1.從上面定位到的元素屬性中,可以看到每個(gè)元素都有tag(標(biāo)簽)屬性,如搜索框的標(biāo)簽屬性,就是最前面的input。
2.很明顯,在一個(gè)頁(yè)面中,相同的標(biāo)簽有很多,所以一般不用標(biāo)簽來(lái)定位。以下例子,僅供參考和理解,運(yùn)行肯定報(bào)錯(cuò)。

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

在這里插入圖片描述

五、find_element_by_link_text()

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

在這里插入圖片描述

查看頁(yè)面元素:

<a class="mnav" target="_blank"  rel="external nofollow" >hao123</a>

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

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

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

六、find_element_by_partial_link_text()

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

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

from selenium import webdriver
driver = webdriver.Chrome()

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

七、find_element_by_xpath()

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

  • 對(duì)于谷歌瀏覽器來(lái)說(shuō),有自己 的xpath解析工具:鼠標(biāo)移到需要查看的html源碼上,右擊
  • 選擇copycopy
  • xpath,就是源碼的xpath路徑

在這里插入圖片描述

from selenium import webdriver
driver = webdriver.Chrome()

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

八、find_element_by_css_selector()

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

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

選擇copy

copy selector,就是源碼的css路徑

在這里插入圖片描述

from selenium import webdriver
driver = webdriver.Chrome()

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

總結(jié):

在這里插入圖片描述

到此這篇關(guān)于python自動(dòng)化八大定位元素講解的文章就介紹到這了,更多相關(guān)python自動(dòng)化八大定位元素內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 對(duì)python中Json與object轉(zhuǎn)化的方法詳解

    對(duì)python中Json與object轉(zhuǎn)化的方法詳解

    今天小編就為大家分享一篇對(duì)python中Json與object轉(zhuǎn)化的方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • Django中的用戶身份驗(yàn)證示例詳解

    Django中的用戶身份驗(yàn)證示例詳解

    這篇文章主要給大家介紹了關(guān)于Django中用戶身份驗(yàn)證的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用SQL Django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • python網(wǎng)絡(luò)爬蟲實(shí)現(xiàn)個(gè)性化音樂(lè)播放器示例解析

    python網(wǎng)絡(luò)爬蟲實(shí)現(xiàn)個(gè)性化音樂(lè)播放器示例解析

    這篇文章主要為大家介紹了使用python網(wǎng)絡(luò)爬蟲實(shí)現(xiàn)個(gè)性化音樂(lè)播放器的詳細(xì)示例代碼以及內(nèi)容解析,有需要的朋友?可以借鑒參考下希望能夠有所幫助
    2022-03-03
  • Python 結(jié)構(gòu)化字符串中提取數(shù)據(jù)詳情

    Python 結(jié)構(gòu)化字符串中提取數(shù)據(jù)詳情

    這篇文章主要介紹了Python 結(jié)構(gòu)化字符串中提取數(shù)據(jù)詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • python根據(jù)出生日期獲得年齡的方法

    python根據(jù)出生日期獲得年齡的方法

    這篇文章主要介紹了python根據(jù)出生日期獲得年齡的方法,涉及Python操作日期的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • Python中reset_index()函數(shù)的使用

    Python中reset_index()函數(shù)的使用

    本文主要介紹了Python中reset_index()函數(shù)的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 使用Python webdriver圖書館搶座自動(dòng)預(yù)約的正確方法

    使用Python webdriver圖書館搶座自動(dòng)預(yù)約的正確方法

    這篇文章主要介紹了使用Python webdriver圖書館搶座自動(dòng)預(yù)約的正確方法,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • python中的變量與內(nèi)存用法

    python中的變量與內(nèi)存用法

    這篇文章主要介紹了python變量與內(nèi)存用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Python高效處理大文件的方法詳解

    Python高效處理大文件的方法詳解

    在這篇文章中,我們將學(xué)習(xí)如何使用multiprocessing、joblib和tqdm?Python包減少大文件的處理時(shí)間。這是一個(gè)簡(jiǎn)單的教程,可以適用于任何文件、數(shù)據(jù)庫(kù)、圖像、視頻和音頻,感興趣的可以了解一下
    2022-07-07
  • Python實(shí)現(xiàn)的旋轉(zhuǎn)數(shù)組功能算法示例

    Python實(shí)現(xiàn)的旋轉(zhuǎn)數(shù)組功能算法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)的旋轉(zhuǎn)數(shù)組功能算法,結(jié)合實(shí)例形式總結(jié)分析了數(shù)組旋轉(zhuǎn)算法的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-02-02

最新評(píng)論