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!

推薦閱讀: