自动化UI测试元素定位精炼

嗨。大家好,我是兰若姐姐。

今天给大家总结下元素定位的方式,直接上干货!

1. ID定位 (ID Selector)

使用元素的唯一ID属性进行定位。

python 复制代码
element = driver.find_element_by_id("element_id")

2. Name定位 (Name Selector)

使用元素的Name属性进行定位。

python 复制代码
element = driver.find_element_by_name("element_name")

3. Class Name定位 (Class Name Selector)

使用元素的Class Name属性进行定位。

python 复制代码
element = driver.find_element_by_class_name("element_class_name")

4. Tag Name定位 (Tag Name Selector)

使用元素的HTML标签名称进行定位。

python 复制代码
element = driver.find_element_by_tag_name("input")

5. XPath定位 (XPath Selector)

使用XPath表达式进行定位,适用于更加复杂的结构。

python 复制代码
# 绝对路径

element = driver.find_element_by_xpath("/html/body/div[1]/div[2]/input")

# 相对路径

element = driver.find_element_by_xpath("//input[@id='element_id']")

6. CSS Selector定位 (CSS Selector)

使用CSS选择器进行定位,支持多种灵活的选择方式。

python 复制代码
# 选择ID

element = driver.find_element_by_css_selector("#element_id")

# 选择Class

element = driver.find_element_by_css_selector(".element_class_name")

# 选择属性

element = driver.find_element_by_css_selector("input[name='element_name']")

使用完整的超链接文本进行定位。

python 复制代码
element = driver.find_element_by_link_text("Click here")

使用部分超链接文本进行定位。

python 复制代码
element = driver.find_element_by_partial_link_text("Click")

9. DOM定位 (DOM Selector)

直接操作Document Object Model(DOM)进行元素定位。

python 复制代码
element = driver.execute_script('return document.getElementById("element_id");')

10. Accessibility ID定位 (Accessibility ID)

主要用于移动应用自动化测试。

python 复制代码
element = driver.find_element_by_accessibility_id("accessibility_id")

示例:

假设有一个网页,其部分HTML结构如下:

html 复制代码
<html>

<body>

<div id="main">

<input id="username" name="username" class="input-field" type="text"/>

<button id="submit-btn" class="button-class" type="submit">Submit</button>

<a href="home.html">Home</a>

</div>

</body>

</html>
  1. ID定位:
python 复制代码
element = driver.find_element_by_id("username")
  1. Name定位:
python 复制代码
element = driver.find_element_by_name("username")
  1. Class Name定位:
python 复制代码
element = driver.find_element_by_class_name("input-field")
  1. Tag Name定位:
python 复制代码
element = driver.find_element_by_tag_name("input")
  1. XPath定位:
python 复制代码
element = driver.find_element_by_xpath("//input[@id='username']")
  1. CSS Selector定位:
python 复制代码
element = driver.find_element_by_css_selector("#username")
  1. Link Text定位:
python 复制代码
element = driver.find_element_by_link_text("Home")
  1. Partial Link Text定位:
python 复制代码
element = driver.find_element_by_partial_link_text("Ho")
  1. DOM定位:
python 复制代码
element = driver.execute_script('return document.getElementById("username");')

通过这些常见的元素定位方式,你可以在自动化测试中灵活地选择适合的方式来定位网页元素,从而实现高效和可靠的测试脚本。

相关推荐
小二·1 分钟前
Python Web 开发进阶实战:全链路测试体系 —— Pytest + Playwright + Vitest 构建高可靠交付流水线
前端·python·pytest
皇族崛起2 分钟前
【视觉多模态】基于视觉AI的人物轨迹生成方案
人工智能·python·计算机视觉·图文多模态·视觉多模态
HealthScience3 分钟前
常见的微调的方式有哪些?(Lora...)
vscode·python
nimadan127 分钟前
**免费有声书配音软件2025推荐,高拟真度AI配音与多场景
人工智能·python
可触的未来,发芽的智生14 分钟前
完全原生态思考:从零学习的本质探索→刻石头
javascript·人工智能·python·神经网络·程序人生
叫我:松哥15 分钟前
基于Flask+ECharts+Bootstrap构建的微博智能数据分析大屏
人工智能·python·信息可视化·数据分析·flask·bootstrap·echarts
Pyeako25 分钟前
Opencv计算机视觉--边界填充&图像形态学
人工智能·python·opencv·计算机视觉·pycharm·图像形态学·边缘填充
深蓝海拓31 分钟前
PySide6,QEventLoop.exec()的使用
笔记·python·qt·学习·pyqt
中等生31 分钟前
Fastapi中的 lifespan
python
小北方城市网33 分钟前
微服务架构设计实战指南:从拆分到落地,构建高可用分布式系统
java·运维·数据库·分布式·python·微服务