前言
当我们在使用 selenium 进行自动化测试工作时,元素定位是非常重要的一环,因为我们是借助脚本模拟我们通过鼠标和键盘对元素进行点击、输入内容和滑动操作的,所以准确的元素定位是我们执行测试脚本的重要一环。本文就来给大家介绍一下 selenium 的元素定位方式。
find_element 和 find_elements
元素定位有两个表达式,分别为find_element()和find_elements(),它们的不同点如下:
Xpath 定位
Xpath 定位方法是基本的一类定位方法,XPath(XML Path Language)是一种用于定位 XML 和 HTML 文档中元素的语言。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By
# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com")# 通过xpath定位输入框,输入内容seleniumbrowser.find_element(By.XPATH, '//input[@id="kw"]').send_keys('selenium')# 停留五秒后关闭浏览器time.sleep(5)browser.quit()
复制代码
这个 XPath 表达式将会匹配id为kw的input元素。
css 定位
CSS 选择器是一种强大且常用的定位方式。它能够通过元素的属性、标签名、类名等准确地定位到页面元素。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By
# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com")# 通过css定位输入框,输入内容seleniumbrowser.find_element(By.CSS_SELECTOR, '.s_ipt').send_keys('selenium')# 停留五秒后关闭浏览器time.sleep(5)browser.quit()
复制代码
id 定位
根据元素的id属性值定位,最为方便且唯一,但是现在很多元素的 id 都是动态生成的,在使用id属性定位时需要注意。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By
# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com")# 通过ID定位输入框,输入内容seleniumbrowser.find_element(By.ID, 'kw').send_keys('selenium')# 停留五秒后关闭浏览器time.sleep(5)browser.quit()
复制代码
name 定位
根据元素的name属性值定位,但是我们需要注意,定位到的元素可能并不是唯一的。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com/")# 通过name属性选择文本框元素,并设置内容browser.find_element(By.NAME,'wd').send_keys("selenium")# 通过通过ID属性获取“百度一下”按钮,并执行点击操作browser.find_element(By.ID,"su").click()# 停留五秒后关闭浏览器time.sleep(5)browser.quit()
复制代码
class 定位
class 定位,根据元素的 class 属性值定位,但可能受 JS 影响动态变化。定位到的标签不一定是唯一的。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com/")time.sleep(2)# 通过class属性选择元素browser.find_element(By.CLASS_NAME,'s_ipt').send_keys("selenium")time.sleep(2)browser.find_element(By.ID,"su").click()# 停留三秒后关闭浏览器time.sleep(3)browser.quit()
复制代码
tag 定位
tag name 定位,根据元素的标签名定位,定位到的标签不一定是唯一的。其在自动化脚本中使用的例子如下:
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By# 启动并打开指定页面browser = webdriver.Firefox()browser.get("https://www.baidu.com")time.sleep(2)# 选择<button></button>标签(搜索按钮),执行点击操作browser.find_element(By.TAG_NAME, "button").click()# 停留三秒后关闭浏览器time.sleep(3)browser.quit()
复制代码
link 定位
link表示包含有属性href的标签元素,如:<a href="https://www.csdn.net">linktext</a>可以通过LINK_TEXT进行定位。
find_element(By.LINK_TEXT,'XX')根据链接文本全匹配进行精确定位。
find_element(By.PARTIAL_LINK_TEXT,'XX')根据链接文本模糊匹配进行定位。
By.LINK_TEXT精确定位
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com")# 选择https://news.baidu.com/标签,执行点击操作browser.find_element(By.LINK_TEXT, "新闻").click()# 停留三秒后关闭浏览器time.sleep(3)browser.quit()
复制代码
By.PARTIAL_LINK_TEXT模糊定位
import time# 导入selenium包from selenium import webdriverfrom selenium.webdriver.common.by import By# 启动并打开指定页面browser = webdriver.Chrome()browser.get("https://www.baidu.com")# 选择https://news.baidu.com/标签,执行点击操作browser.find_element(By.PARTIAL_LINK_TEXT, "新").click()# 停留三秒后关闭浏览器time.sleep(3)browser.quit()
复制代码
总结
本文主要介绍了 selenium 常用的几种元素定位方法,灵活地使用元素定位方法对于提高我们查找元素定位效率,提升测试脚本的健壮性有很大帮助,希望本文能够帮到大家。
更多Python基础语法趣味学习视频,请点击!
评论