Selenium?4.2.0?標(biāo)簽定位8種方法詳解
背景
Selenium4使用find_element(by=By.**, value=*)來替換了原來的find_element_by_* 的方法,使用find_elements(by=By.*, value=*)來替換了原來的find_elements_by_* 的方法。
By類定義在 site-packages\selenium\webdriver\common\by.py中:
這就是Selenium4的8種定位方法
元素定位
元素本身是什么:HTML靜態(tài)頁面中的的一個標(biāo)簽
元素定位一般而言是基于元素自身所包含有的特點(diǎn)來進(jìn)行定位的。
包括:標(biāo)簽的名稱(決定元素是什么)、標(biāo)簽的屬性(決定元素有什么特質(zhì)),標(biāo)簽的文本
定位元素的方法
ID = “id”
XPATH = “xpath”
LINK_TEXT = “link text”
PARTIAL_LINK_TEXT = “partial link text”
NAME = “name”
TAG_NAME = “tag name”
CLASS_NAME = “class name”
CSS_SELECTOR = “css selector”
- id:有ID就用ID定位,基本不會重復(fù)
- name:有name可以考慮用,name類似于人的名字,雖然相對少見的值,但是容易重名
- link text:基于文本定位鏈接標(biāo)簽
- partial link text:類似于SQL中的like%,模糊查找
- tag name:基于標(biāo)簽名稱來查找元素,大概率有多個結(jié)果,一般用于查找多個重復(fù)的內(nèi)容的時候使用。
- class:基于class屬性進(jìn)行元素查找,非必要不推薦,重復(fù)率高
- css selector:定位界萬金油,有自己的獨(dú)特語法,定位語法麻煩,基于標(biāo)簽的class內(nèi)容進(jìn)行定位,使用copy
- selector確定位置
xpath:定位界萬金油,有自己的獨(dú)特語法,定位速度慢,基于樹狀結(jié)構(gòu)形態(tài)定位,使用Copy XPath, Copy full
XPath來確定位置
總結(jié):有id用id,沒id用name,都不行用css/xpath,鏈接可以用link text。find_element元素定位如果同時有多個結(jié)果,默認(rèn)返回定位的第一個結(jié)果;find_elements元素定位返回一個列表
實(shí)例
測試目的
測試Selenium4的8種元素定位方法
ID、CSS_SELECTOR
輸入欄輸入yoga,點(diǎn)擊搜索
實(shí)例網(wǎng)站
京東
實(shí)例代碼
import time from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.service import Service service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe") driver = webdriver.Chrome(service=service) driver.get(url="https://www.jd.com/") # id driver.find_element(by=By.ID,value="key").send_keys("yoga") # css selector driver.find_element(by=By.CSS_SELECTOR,value="#search > div > div.form > button").click() time.sleep(3) driver.quit()
結(jié)果展示
NAME、LINK_TEXT、PARTIAL_LINK_TEXT
用NAME元素輸入yoga,用LINK_TEXT定位how123,用PARTIAL_LINK_TEXT定位hao123
實(shí)例網(wǎng)站
可以自行百度
實(shí)例代碼
import time from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.service import Service service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe") driver = webdriver.Chrome(service=service) driver.get(url="https://www.baidu.com/") # id driver.find_element(by=By.NAME,value="wd").send_keys("yoga") time.sleep(3) driver.get(url="https://www.baidu.com/") # link text driver.find_element(by=By.LINK_TEXT,value="hao123").click() time.sleep(3) # css selector driver.get(url="https://www.baidu.com/") driver.find_element(by=By.PARTIAL_LINK_TEXT,value="1").click() time.sleep(3) driver.quit()
結(jié)果展示
CSS、XPATH
點(diǎn)擊熱搜第一
實(shí)例網(wǎng)站
實(shí)例代碼
import time from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.service import Service service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe") driver = webdriver.Chrome(service=service) driver.get(url="https://weibo.com/newlogin?tabtype=search&openLoginLayer=0&url=") time.sleep(6) # Redirect # css selector driver.find_element(by=By.CSS_SELECTOR,value="#scroller > div.vue-recycle-scroller__item-wrapper > div:nth-child(2) > div > div > a > div > div > div.woo-box-item-flex").click() time.sleep(3) # xpath driver.get(url="https://weibo.com/newlogin?tabtype=search&openLoginLayer=0&url=") time.sleep(6) driver.find_element(by=By.XPATH,value='//*[@id="scroller"]/div[1]/div[2]/div/div/a/div/div/div[1]').click() time.sleep(3) driver.quit()
結(jié)果展示
CSDN判定圖片違規(guī),無法上傳
TAG_NAME、CLASS
去除首頁作弊通知彈窗
實(shí)例平臺
實(shí)例代碼
import time from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.chrome.service import Service service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe") driver = webdriver.Chrome(service=service) driver.get(url="http://doudouwan.com/") # tag name el = driver.find_elements(by=By.TAG_NAME,value="a")[83] # el2 = driver.find_elements(by=By.CLASS_NAME,value='layui-layer-btn0')[0] # for i in range(len(el)): # if el[i] == el2: # print(i) time.sleep(3) # delete all cookies in this website, and do not need to refresh driver driver.delete_all_cookies() # xpath driver.get(url="http://doudouwan.com/") time.sleep(6) driver.find_elements(by=By.CLASS_NAME,value='layui-layer-btn0')[0].click() time.sleep(3) driver.quit()
結(jié)果展示
到此這篇關(guān)于Selenium 4.2.0 標(biāo)簽定位8種方法的文章就介紹到這了,更多相關(guān)Selenium標(biāo)簽定位內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中的reduce內(nèi)建函數(shù)使用方法指南
python中的reduce內(nèi)建函數(shù)是一個二元操作函數(shù),他用來將一個數(shù)據(jù)集合(鏈表,元組等)中的所有數(shù)據(jù)進(jìn)行下列操作:用傳給reduce中的函數(shù) func()(必須是一個二元操作函數(shù))先對集合中的第1,2個數(shù)據(jù)進(jìn)行操作,得到的結(jié)果再與第三個數(shù)據(jù)用func()函數(shù)運(yùn)算,最后得到一個結(jié)果2014-08-08python科學(xué)計(jì)算之scipy——optimize用法
今天小編就為大家分享一篇python科學(xué)計(jì)算之scipy——optimize用法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11Python實(shí)現(xiàn)獲取內(nèi)網(wǎng)IP地址的方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了五種利用Python語言實(shí)現(xiàn)獲取內(nèi)網(wǎng)IP地址的方法,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以了解一下2023-03-03Python 進(jìn)程操作之進(jìn)程間通過隊(duì)列共享數(shù)據(jù),隊(duì)列Queue簡單示例
這篇文章主要介紹了Python 進(jìn)程操作之進(jìn)程間通過隊(duì)列共享數(shù)據(jù),隊(duì)列Queue,結(jié)合實(shí)例形式分析了Python進(jìn)程數(shù)據(jù)共享、隊(duì)列數(shù)據(jù)處理相關(guān)操作技巧,需要的朋友可以參考下2019-10-10python 輸出列表元素實(shí)例(以空格/逗號為分隔符)
今天小編就為大家分享一篇python 輸出列表元素實(shí)例(以空格/逗號為分隔符),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12如何將json數(shù)據(jù)轉(zhuǎn)換為python數(shù)據(jù)
這篇文章主要介紹了如何將json數(shù)據(jù)轉(zhuǎn)換為python數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09