实现元素定位:掌握Selenium八大定位方法

文章目录

  • [0. 八大定位方法](#0. 八大定位方法)
  • [1. id](#1. id)
  • [2. name](#2. name)
  • [3. xpath](#3. xpath)
  • [4. css_selector](#4. css_selector)

0. 八大定位方法

当实现测试自动化,编写测试用例时,首先需要在web界面找到对应元素位置,而Selenium提供了一套对应的API,被封装在WebDriver类中。如下图,分别对应八种定位方法。下面再详细介绍。

  1. By.ID:通过元素的 ID 查找。
  2. By.NAME:通过元素的 name 属性查找。
  3. By.XPATH:通过 XPath 表达式查找。
  4. By.LINK_TEXT:通过链接文本查找。
  5. By.PARTIAL_LINK_TEXT:通过链接的部分文本查找。
  6. By.TAG_NAME:通过元素的标签名查找。
  7. By.CLASS_NAME:通过元素的类名查找。
    By.CSS_SELECTOR:通过 CSS 选择器查找。

1. id

从浏览器获得元素ID

1.F12打开当前页面控制台

2.可以打开元素,进行查找,也可以点击左上角箭头,再点击web页面上需要的元素,如图

python 复制代码
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()  # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com')  # get可以打开一个url
sleep(2)
#  find_element是webdriver中的方法,用来查找网页元素
#  By.ID是一个定位器,ID就是通过ID的方法定位,'kw'就是元素id
#  send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.ID, 'kw').send_keys('selenium')
sleep(2)
#  click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
#  退出
driver.quit()

2. name

除了id,还可以使用name标签,使用起来和name一样,但是需要注意web页面元素name理论上不要重复,但是是可以重复的,所以获得是当前页面的第一个name标签元素。

python 复制代码
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()  # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com')  # get可以打开一个url
sleep(2)
#  find_element是webdriver中的方法,用来查找网页元素
#  By.NAME是一个定位器,NAME就是通过NAME的方法定位,'wd'就是元素name
#  send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.NAME, 'wd').send_keys('selenium')
sleep(2)
#  click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
#  退出
driver.quit()

3. xpath

xpath是通过路径的方式获得元素的,一般通过id和name的方式获得元素位置,这是非常简单的,但有时我们无法获得id和name,就可以通过xpath,xpath基本上可以获得任何元素的精准位置,但是获得的速度相对来说比较慢,而且使用xpath获得元素位置,当页面进行修改,元素位置发生改变,我们前面的脚本有时就需要修改,所以页面如果频繁较大修改,可以减少xpath的使用。

如上图,我们可以通过双击元素,点击'复制',再点击'复制xpath',这里是一个相对路径,下面还有一个完整xpath,这个是绝对路径,绝对路径对页面结构依赖性比较高,定位元素速度不如相对路径。

python 复制代码
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()  # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com')  # get可以打开一个url
sleep(2)
#  find_element是webdriver中的方法,用来查找网页元素
#  By.XPATH是一个定位器,XPATH就是通过XPATH的方法定位,'//*[@id="kw'就是元素xpath
#  send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.XPATH, '//*[@id="kw"]').send_keys('selenium')
sleep(2)
#  click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
#  退出
driver.quit()

4. css_selector

除了上面三种,还可以通过css选择器进行定位,css选择器的语法比较简洁,使用起来速度比xpath快,可以通过id、name、class等进行定位。例如:id选择器:使用#符号后跟元素的ID属性值来选择元素,如#myElement;类选择器:使用.符号后跟元素的class属性值来选择元素,如.myClass。

当然,还有个简单的方法,直接从浏览器上进行复制,点击【复制selector】:

python 复制代码
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()  # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com')  # get可以打开一个url
sleep(2)
#  find_element是webdriver中的方法,用来查找网页元素
#  By.CSS_SELECTOR是一个定位器
#  send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.CSS_SELECTOR, '#kw').send_keys('selenium')
sleep(2)
#  click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
#  退出
driver.quit()

以上重点介绍个四种,其实每种使用起来基本上相同,就是各有优劣而已。其他四种就和它们的名字相同,大家可以自行尝试一下。

相关推荐
ClouGence1 天前
Selenium、Playwright、CueCast 深度对比:Web 自动化测试工具怎么选
selenium·测试
程序员小远16 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
LT101579744416 天前
2026年Web自动化测试工具选型指南:多浏览器兼容解决方案
前端·测试工具·自动化
程序员三藏17 天前
Web自动化测试详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
深蓝电商API17 天前
Selenium 5.0 全新架构解析:值得升级吗?
爬虫·selenium
专业机床数据采集17 天前
基于 Wireshark 抓包逆向设备通信协议,并用 C# UDP协议跨平台 实现宝元数控程序列表读取、上传、下载和删除
网络·测试工具·wireshark·程序传输·宝元数控·dnc·数控程序传输
程序员龙叔17 天前
从 0 开始学习 AI 测试 - 从接口测试来教你如何用 AI 来生成自动化测试代码
自动化测试·软件测试·python·软件测试工程师·测试工具·性能测试·ai测试
Saniffer_SH17 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
川石课堂软件测试17 天前
APP自动化测试|高级手势操作&toast操作
css·功能测试·测试工具·microsoft·fiddler·单元测试·harmonyos