实现元素定位:掌握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()

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

相关推荐
天堂的恶魔9467 分钟前
软件测试 ——Postman(Newman的使用)
测试工具·postman
天堂的恶魔9461 天前
软件测试 —— Postman(全局变量和环境变量,请求前置脚本,关联)
测试工具·lua·postman
moton20172 天前
5步打造完善的物联网IoT测试体系
物联网·测试工具·可用性测试·iot·物联网测试·测试体系
门豪杰2 天前
使用Chrome和Selenium实现对Superset等私域网站的截图
前端·chrome·selenium·superset·截图
m0_748248772 天前
小白爬虫——selenium入门超详细教程
爬虫·selenium·测试工具
清风细雨_林木木2 天前
Postman的使用
测试工具·postman
北京-宏哥2 天前
PC端自动化测试实战教程-1-pywinauto 环境搭建(详细教程)
windows·python·测试工具·pycharm·自动化
Feng.Lee2 天前
性能测试实时监听工具Influx+Grafana
测试工具·jmeter·grafana
??? Meggie3 天前
【Python】使用 selenium模拟敲键盘输入的方法汇总
开发语言·python·selenium