Selenium工具使用Python实现下拉框定位操作

news/2024/10/22 16:25:02/

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

我们通常遇到的下拉框有显性的下拉框和隐性的下拉框;有的下拉框还可以进行单选或多选操作,在selenium中如何实现下拉框的定位通常使用select标签进行定位。

对于一些页面中隐性的下拉框,则需要CSS/JS动态加载,非标准的HTML SELECT元素,通过Python语言如何实现定位,让我们一起来研究一下吧.

select 的方法列表如下:

图片

显性的下拉框定位:

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import Select# 初始化浏览器驱动
driver = webdriver.Chrome()# 假设我们要操作一个下拉框,先定位到该元素
select_element = driver.find_element(By.ID, "example_dropdown")  # 根据ID定位下拉框# 创建一个Select对象实例
dropdown = Select(select_element)# 下面是针对下拉框的一些基本操作方法:# 选择下拉框中的某个选项(根据显示文本)
dropdown.select_by_visible_text("Option Text")# 或者根据选项值选择
dropdown.select_by_value("option_value")# 也可以根据索引选择
dropdown.select_by_index(1)  # 索引从0开始计数# 取消选择(多选框适用)
dropdown.deselect_all()  # 取消所有已选项
dropdown.deselect_by_visible_text("Option Text")  # 根据文本取消选择
dropdown.deselect_by_value("option_value")  # 根据值取消选择
dropdown.deselect_by_index(1)  # 根据索引取消选择# 获取所有选项
options = dropdown.options
for option in options:print(option.text)# 判断某个选项是否被选中
is_selected = dropdown.is_selected_by_visible_text("Option Text")# 最后,别忘了关闭浏览器
driver.quit()

注意:在执行这些操作前,确保页面已经加载完成,如果需要的话,可以使用time.sleep()或者WebDriverWait配合Expected Conditions等待元素可见或可交互。

隐性的下拉框定位:

CSS/JS动态加载:

  • 当下拉框内容在用户交互(如点击)后通过JavaScript动态生成时,Selenium需要模拟相应的用户操作来触发下拉框的显示。例如,如果下拉框是一个按钮或者链接触发的,你需要先定位并点击这个触发元素。

# 假设有一个按钮或链接元素触发下拉框显示
trigger_element = driver.find_element(By.ID, "dropdown_trigger")
trigger_element.click()# 等待下拉框内容加载出来
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as ECwait = WebDriverWait(driver, 10)
dropdown_list = wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, ".hidden-dropdown .option"))) # 如果是多级联动或者复杂的选择逻辑,可能还需要进一步处理

非标准HTML Select元素:

  • 若下拉框并非标准HTML <select>标签实现,而是一个自定义组件(比如使用div、ul、li结构模拟),则不能直接使用Select类进行操作。这时,你可能需要直接操作DOM,通过点击、发送键盘事件等方式触发下拉框,并根据其内部结构定位和点击选项。

# 定位到隐藏下拉框的触发区域
dropdown_area = driver.find_element(By.CSS_SELECTOR, "#custom_dropdown")# 触发下拉框显示
dropdown_area.click()# 等待下拉框内容展示
wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, "#custom_dropdown ul.dropdown-list")))# 再定位到具体的选项并点击
option_to_select = driver.find_element(By.CSS_SELECTOR, "#custom_dropdown ul.dropdown-list li.option_text")
option_to_select.click()

重要的是理解页面的具体实现方式,以便确定正确的交互方法。在处理这类问题时,常常需要查看网页源码、开发者工具中的DOM结构以及网络请求等信息,以准确模拟用户的操作行为。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。


http://www.ppmy.cn/news/1514579.html

相关文章

未来的社交网络:人工智能如何推动Facebook的发展

在当今数字化飞速发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;已成为推动各行业进步的核心动力之一。社交媒体巨头Facebook凭借其在人工智能领域的深厚积累&#xff0c;正逐步将AI技术融入平台的各个方面&#xff0c;重新定义用户体验&#xff0c;并引领社交网络…

禁止浏览器默认填充密码 vue

禁止浏览器默认填充密码会和我的样式冲突 所以禁止 第一种&#xff1a; 通过给表单元素添加 autocomplete"off" 属性&#xff0c; 可以防止浏览器自动填充表单中的账号和密码。可以在 input 标签或整个 form 标签上使用&#xff1a; <template><a-form&g…

C++资料电子书资源PDF免费分享

C电子书 这里写目录标题 C电子书目录资源获取 目录 《数据结构(C语言版)》(严蔚敏 吴伟明编著).pdf 7.6MB 《C程序设计题解与上机指导》(第二版).谭浩强.pdf 7.0MB 《C程序设计(第四版)学习辅导》.谭浩强.扫描版.pdf 13.1MB 《C程序设计》第一版&#xff08;谭浩强&#xff09…

网络工程师学习笔记——数据通信

学习网络的基础就是数通&#xff0c;首先得了解数据在网络上是如何传输&#xff0c;以及在传输过程中是使用什么方式进行传输&#xff0c;以及是如何到达接受方和如何解压和加密的等等。 数字编码技术 有基本编码&#xff08;单极性码&#xff0c;极性码&#xff0c;双极性码…

计算机二级题--指针 章节

1.概念 1.函数名代表函数的入口地址 2.交换地址 1.*s,说明s是一个指针变量 2.s&k;说明让s指向k地址 3.所以*sk实际上与上面那句是等价的,因此m一直都没有什么变化依然是3 4.k是全局变量所以是5 3&#xff0c;7&#xff1b;改变s指向之后&#xff0c;又将值赋给了s指向的…

Cobalt Strike 4.8 用户指南-第二节-用户界面

2.1、概述 Cobalt Strike用户界面分为两部分。界面顶部显示会话或目标的可视化。界面底部显示与你交互的每个 Cobalt Strike 功能或会话的选项卡。可以单击这两个部分之间的区域并根据自己的喜好调整它们的大小。 # 2.2、工具栏 顶部的工具栏提供对常见 Cobalt Strike功能的快…

2024“钉耙编程”中国大学生算法设计超级联赛(8)

&#x1f680;欢迎来到本文&#x1f680; &#x1f349;个人简介&#xff1a;陈童学哦&#xff0c;彩笔ACMer一枚。 &#x1f3c0;所属专栏&#xff1a;杭电多校集训 本文用于记录回顾总结解题思路便于加深理解。 不是哥们&#xff0c;怎么我tm什么都不会。 &#x1f4e2;&…

案·理探析 | 网络爬虫技术滥用的刑事责任

案理探析 | 网络爬虫技术滥用的刑事责任 刘荣 王爱强 中国检察官 2021年10月31日 19:32 北京 摘 要&#xff1a;网络爬虫是高效收集、分类、整理海量网络信息的程序或者脚本&#xff0c;具有很高的实用价值。但当网络爬虫使用者为了获取经济利益&#xff0c;将其作为犯罪工具…