Web UI自动化测试学习系列5--基础知识1--常用元素定位1

测试学习记录,仅供参考!

selenium八大常用元素定位

元素定位是 web ui 自动化最关键的一部分;

1、打开 XAMPP Control Panel 控制面板→启动 apache 和 MySQL 服务;

2、成功启动 apache 和 MySQL 服务后,打开开源电商商城系统首页,单击'登录'按钮,打开登录页面;

3、 在登录页单击'注册'或者'立即注册'按钮,进入注册新会员页面,打开开发者工具;

(开发人员工具、开发工具,叫法不同,快捷键:F12 或者鼠标右键单击菜单选择'检查')

ps:浏览器开发者工具烦请自行学习其相关操作(这里使用的 edge 浏览器)

4、鼠标单击开发者工具中的元素定位按钮,鼠标光标悬停在'用户名'标签后的文本输入框上;(未单击选中时是置灰色的,点击选中后呈蓝色;下图红色箭头指示,最左侧的一个按钮,这里仅供参考,若有区别请自行解决;)

5、 在项目根目录下新建一个名称为 element_local.py 的 Python 文件;(取一个符合命名规则的文件名)

复制代码
# 导包--先引入库,把 selenium webdriver 引进来
from selenium import webdriver
# 把元素定位 BY 类 引进来
from selenium.webdriver.common.by import By

# 实例化edge浏览器--通过webdriver驱动一个浏览器
driver = webdriver.Edge()

# 打开网页--打开一个浏览器,地址是注册页面地址
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个ID元素定位
ele = driver.find_element(By.ID, 'username')
# 打印一下查看有木有取到,能不能定位到
print(ele)

6、 此运行结果说明是 能够取到的,可以正常定位到,是没有问题的

复制代码
<selenium.webdriver.remote.webelement.WebElement (session="8df5b5256340a6b8191290ec242338d5", element="f.BF77FA6F12328E23045A9971BC56450F.d.247E3EE845B4CADE366E03ADBDC718BD.e.9")>

进程已结束,退出代码为 0

一、ID 元素定位

7、id 元素定位, id 是标签的唯一属性,可以通过 id 属性来唯一定位一个元素;

复制代码
driver.find_element(By.ID, 'username')

二、NAME 元素定位

8、name 元素定位,基于标签中的 name 属性来进行定位;

复制代码
driver.find_element(By.NAME, 'username')

9、 优化 element_local.py 文件;

复制代码
# 导包
from selenium import webdriver
from selenium.webdriver.common.by import By

# 实例化edge浏览器
driver = webdriver.Edge()

# 打开网页
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个 ID 元素定位
driver.find_element(By.ID, 'username')

# 第二个 NAME 属性定位
ele = driver.find_element(By.NAME, 'username')
print(ele)

三、CLASS_NAME 元素定位

10、class_name 元素定位,基于 html 标签中的 class 属性来进行定位;

复制代码
driver.find_element(By.CLASS_NAME, 'inputBg')

11、 优化 element_local.py 文件--调试查看有木有拿到这个元素,最好是打印一下;

复制代码
# 导包
from selenium import webdriver
from selenium.webdriver.common.by import By

# 实例化edge浏览器
driver = webdriver.Edge()

# 打开网页
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个 ID 元素定位
driver.find_element(By.ID, 'username')

# 第二个 NAME 属性定位
driver.find_element(By.NAME, 'username')

# 第三个 CLASS_NAME 属性定位
ele = driver.find_element(By.CLASS_NAME, 'inputBg')
print(ele)

四、TAG_NAME 元素定位 (标签名元素定位)

12、tag_name 元素定位,基于 html 中的标签名来进行定位;

复制代码
driver.find_element(By.TAG_NAME, 'input')

13、 优化 element_local.py 文件;

复制代码
# 导包
from selenium import webdriver
from selenium.webdriver.common.by import By

# 实例化edge浏览器
driver = webdriver.Edge()

# 打开网页
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个 ID 元素定位
driver.find_element(By.ID, 'username')

# 第二个 NAME 属性定位
driver.find_element(By.NAME, 'username')

# 第三个 CLASS_NAME 元素定位
driver.find_element(By.CLASS_NAME, 'inputBg')

# 第四种 TAG_NAME 元素定位
ele = driver.find_element(By.TAG_NAME, 'input')
print(ele)

14、LINK_TEXT 完整超链接文本定位 通过完整的超链接文本来定位元素;

复制代码
driver.find_element(By.LINK_TEXT, '我已有账号,我要登录')

例如注册页面中的超链接'用户协议'、'我已有账号,我要登录'、'您忘记密码了吗?',超链接定位是通过超链接的文本去定位,务必注意超链接的文本要写全,且区分大小写;若有多个相同的文本链接时,只会返回第一个匹配的元素;

15、 优化 element_local.py 文件;添加时间模块等待函数,防止浏览器过快关闭看不到效果;

复制代码
# 导包
from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep

# 实例化edge浏览器
driver = webdriver.Edge()

# 打开网页
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个 ID 元素定位
driver.find_element(By.ID, 'username')

# 第二个 NAME 属性定位
driver.find_element(By.NAME, 'username')

# 第三个 CLASS_NAME 元素定位
driver.find_element(By.CLASS_NAME, 'inputBg')

# 第四种 TAG_NAME 元素定位
driver.find_element(By.TAG_NAME, 'input')

# 第五种 LINK_TEXT 完整超链接文本定位--单击操作 click() 点击效果
driver.find_element(By.LINK_TEXT, '我已有账号,我要登录').click()
#页面等待3秒
sleep(3)
# 关闭浏览器
driver.quit()

以'我已有账号,我要登录'为例,增加单击 click() 方法,添加时间模块,浏览器页面等待指定时间再关闭,出现登录页面则表示超链接文本定位成功;

16、PARTIAL_LINK_TEXT 部分超链接文本定位 通过超链接文本的部分内容来定位元素,对大小写敏感;若有多个相同的文本链接时,只会返回第一个匹配的元素;

复制代码
driver.find_element(By.PARTIAL_LINK_TEXT, '我要登录')

17、 优化 element_local.py 文件;

复制代码
# 导包
from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep

# 实例化edge浏览器
driver = webdriver.Edge()

# 打开网页
driver.get('http://localhost:8088/ecshop/user.php?act=register')

# 第一个 ID 元素定位
driver.find_element(By.ID, 'username')

# 第二个 NAME 属性定位
driver.find_element(By.NAME, 'username')

# 第三个 CLASS_NAME 元素定位
driver.find_element(By.CLASS_NAME, 'inputBg')

# 第四种 TAG_NAME 元素定位
driver.find_element(By.TAG_NAME, 'input')

# 第五种 LINK_TEXT 完整超链接文本定位--单击操作 click()
driver.find_element(By.LINK_TEXT, '我已有账号,我要登录')

# 第六种 PARTIAL_LINK_TEXT 部分超链接文本定位--单击操作 click() 点击效果
driver.find_element(By.PARTIAL_LINK_TEXT, '我要登录').click()

#页面等待3秒
sleep(3)
# 关闭浏览器
driver.quit()

未完待续。。。

相关推荐
MarkHD2 小时前
智能体在车联网中的应用:第51天 模仿学习与离线强化学习:破解数据效率与安全困局的双刃剑
学习·安全
tokepson4 小时前
Mysql下载部署方法备份(Windows/Linux)
linux·服务器·windows·mysql
Drawing stars5 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
崇山峻岭之间5 小时前
Matlab学习记录33
开发语言·学习·matlab
小二·5 小时前
Python Web 开发进阶实战:性能压测与调优 —— Locust + Prometheus + Grafana 构建高并发可观测系统
前端·python·prometheus
科技林总6 小时前
【系统分析师】3.5 多处理机系统
学习
王老邪6 小时前
Windows下利用PowerShell实现Git自动推送
windows·git
七牛云行业应用6 小时前
重构实录:我删了 5 家大模型 SDK,只留了 OpenAI 标准库
python·系统架构·大模型·aigc·deepseek
知乎的哥廷根数学学派6 小时前
基于多模态特征融合和可解释性深度学习的工业压缩机异常分类与预测性维护智能诊断(Python)
网络·人工智能·pytorch·python·深度学习·机器学习·分类
一人の梅雨7 小时前
亚马逊SP-API商品详情接口轻量化实战:合规与商业价值提取指南
python