Python selenium 八種定位元素的方式
前言
八種定位方式:
id,name,class name,tag name,link text,partial link text,xpath,css selector。其中id,name,class name,tag name是根據元素的標簽或元素的屬性來進行定位;link text,partial link text是根據超鏈接的文本來進行定位;xpath為元素路徑定位;css為選擇器定位(樣式定位)。
1:id定位
說明:id定位就是通過元素的id屬性來定位元素;
前提:元素有id屬性
id定位方法:find_element_by_id()
示例:打開百度搜索頁面,通過id定位,輸入搜索關鍵字
from selenium import webdriver import time # 打開chrome瀏覽器 driver = webdriver.Chrome() # 打開百度搜索頁面 driver.get('https://www.baidu.com') # 通過id定位 driver.find_element_by_id('kw').send_keys('python') # 強制等待2秒查看效果 time.sleep(2) # 關閉瀏覽器 driver.quit()
2:name定位
說明:HTML規定name屬性來指定元素名稱,name的屬性值在當前文檔中可以不是唯一的,name定位就是根據name屬性來定位。
前提:元素有name屬性
name定位方法:find_element_by_name()
示例:打開百度搜索頁面,通過name定位,輸入搜索關鍵字
from selenium import webdriver import time # 打開chrome瀏覽器 driver = webdriver.Chrome() # 打開百度搜索頁面 driver.get('https://www.baidu.com') # 通過name定位 driver.find_element_by_name('wd').send_keys('python') # 強制等待2秒查看效果 time.sleep(2) # 關閉瀏覽器 driver.quit()
3:class_name定位
說明:HTML規定class來指定元素的類名,class定位就是根據class屬性來定位。
前提:元素有class屬性
class_name定位方法:find_element_by_class_name()
示例:打開百度搜索頁面,通過class_name定位,輸入搜索關鍵字
from selenium import webdriver import time # 打開chrome瀏覽器 driver = webdriver.Chrome() # 打開百度搜索頁面 driver.get('https://www.baidu.com') # 通過class_name定位 driver.find_element_by_class_name('s_ipt').send_keys('python') # 強制等待2秒查看效果 time.sleep(2) # 關閉瀏覽器 driver.quit()
4:tag_name定位
說明:HTML本質就是由不同的tag(標簽)組成,而每個tag都是指同一類,所以tag定位效率低,一般不建議使用;tag_name定位就是通過標簽名來定位。
tag_name定位方法:find_element_by_tag_name()
5:link_text定位
說明:link_text定位與前面4個定位有所不同,它專門用來定位超鏈接文本(文本值)
前提:定位的元素是鏈接標簽(a標簽)
link_text定位方法:find_element_by_link_text()
示例:打開百度首頁,通過link_text定位到hao123按鈕,並進行點擊操作
from selenium import webdriver import time # 打開chrome瀏覽器 driver = webdriver.Chrome() # 打開百度搜索頁面 driver.get('https://www.baidu.com') # 通過link_text定位 driver.find_element_by_link_text('hao123').click() # 強制等待2秒查看效果 time.sleep(2) # 關閉瀏覽器 driver.quit()
6:partial_link_text定位
說明:partial_link_text定位是對link_text定位的補充,partial_link_text為模糊匹配;link_text為精確匹配。
前提:定位的元素是鏈接標簽(a標簽)
partial_link_text定位方法:find_element_by_partial_link_text()
通過傳入a標簽局部文本或全部文本來定位元素,要求輸入的文本能夠唯一找到這個元素
示例:打開百度首頁,通過partial_link_text定位到新聞,並進行點擊操作
from selenium import webdriver import time # 打開chrome瀏覽器 driver = webdriver.Chrome() # 打開百度搜索頁面 driver.get('https://www.baidu.com') # 通過partial_link_text定位 driver.find_element_by_partial_link_text('新').click() # 強制等待2秒查看效果 time.sleep(2) # 關閉瀏覽器 driver.quit()
7:xpath定位
xpath概述:
- 1、xpath即為xml path的簡稱,它是一種用來確定XML文檔中某部分位置的語言。
- 2、HTML可以看做是XML的一種實現,所以selenium用戶可以使用這種強大的語言在web應用中來定位元素。
- 3、xpath為強大的語言,是因為它有非常靈活的定位策略。
xpath定位策略(方式):
- 1、路徑定位–絕對路徑、相對路徑;
- 2、利用元素屬性定位;
- 3、層級與屬性結合定位;
- 4、屬性與邏輯定位結合。
xpath定位方法:find_element_by_xpath()
8:css定位
css概述:
- 1、css(Cascading Style Sheets)是一種語言,它用來描述HTML和XML的元素顯示樣式。
- 2、css語言中有css選擇器,在selenium中也可以使用這種選擇器來進行元素定位。
- 3、css定位方式比xpath快,而且css的語法也非常強大,所以非常推薦這種方式定位。
css定位策略(方式):
- 1、id選擇器
- 2、class選擇器
- 3、元素選擇器
- 4、屬性選擇器
- 5、層級選擇器
css定位方法:find_element_by_css_selector()
到此這篇關於Python selenium 八種定位元素的方式的文章就介紹到這瞭,更多相關Python selenium 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python語言中的Selenium環境搭建
- Python腳本Selenium及頁面Web元素定位詳解
- python自動化八大定位元素講解
- 詳解Python自動化中這八大元素定位
- 全網最全python庫selenium自動化使用詳細教程