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

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

我们通常遇到的下拉框有显性的下拉框和隐性的下拉框;有的下拉框还可以进行单选或多选操作,在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.mzph.cn/diannao/67473.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mysql--实战篇--连接池(连接池原理,HikariCP、C3P0、Druid和DBCP等)

连接池&#xff08;Connection Pool&#xff09;是数据库应用程序中的一种优化技术&#xff0c;用于管理和复用数据库连接。通过连接池&#xff0c;应用程序可以避免频繁创建和销毁数据库连接的开销&#xff0c;从而提高性能和资源利用率。在Java应用程序中&#xff0c;常用的M…

深度学习 Pytorch 张量(Tensor)的创建和常用方法

1 张量的基本创建及其类型 和Numpy中的array一样&#xff0c;张量的本质也是结构化地组织了大量的数据。 并且在实际操作中&#xff0c;张量的创建和基本功能也与其非常类似。 1.1 张量(Tensor)函数创建方法 张量的最基本创建方法和Numpy中创建Array的格式一致。 # Numpy创建…

使用 Continue 插件时,发现调用外部地址

https://us.i.posthog.com/e/?ip1&_1737025525924&ver1.163.0&compressiongzip-js 看是一个帮助改善产品的网址。估计类似某推广流量监控的插件工具吧。网上没用查到其他说明&#xff0c;可能国内使用不多的原因。 但是发送的数据看不出来是个什么内容。 我用来搜…

【PyQt】图像处理系统

[toc]pyqt实现图像处理系统 图像处理系统 1.创建阴影去除ui文件 2.阴影去除代码 1.创建阴影去除ui文件 UI文件效果图&#xff1a; 1.1QT Desiger设置组件 1.两个Pushbutton按钮 2.两个label来显示图像 3.Text Browser来显示输出信息 1.2布局的设置 1.先不使用任何La…

【Idea】编译Spring源码 read timeout 问题

Idea现在是大家工作中用的比较多的开发工具&#xff0c;尤其是做java开发的&#xff0c;那么做java开发&#xff0c;了解spring框架源码是提高自己技能水平的一个方式&#xff0c;所以会从spring 官网下载源码&#xff0c;导入到 Idea 工具并编译&#xff0c;但是发现build的时…

全类别机器人传感器模块推荐

视觉感知 双目视觉模块&#xff1a;常见分辨率1280720&#xff0c;帧率30fps-60fps&#xff0c;水平视场角60-90&#xff0c;垂直视场角40-60&#xff0c;通过USB接口传数据。用于机器人导航、避障等&#xff0c;基于三角测量原理获取三维信息&#xff0c;定位更精准。单目摄像…

Linux 音视频入门到实战专栏(视频篇)视频编解码 MPP

文章目录 一、MPP 介绍二、获取和编译RKMPP库三、视频解码四、视频编码 沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;&#x1f604; &#x1f4e2;本篇将介绍如何调用alsa api来进行音频数据的播放和录制。 一、MPP 介绍 瑞芯微提供的媒体处理软件平台…

爬虫后的数据处理与使用(使用篇--实现分类预测)

&#xff08;&#xff09;紧接上文&#xff0c;在完成基本的数据处理后&#xff0c;接下来就是正常的使用了。当然怎么用&#xff0c;确实需要好好思考一下~ 上文&#xff1a;爬虫后的数据处理与使用&#xff08;处理篇&#xff09; 前言&#xff1a; 一般来说&#xff0c;我…

RabbitMQ--延迟队列

&#xff08;一&#xff09;延迟队列 1.概念 延迟队列是一种特殊的队列&#xff0c;消息被发送后&#xff0c;消费者并不会立刻拿到消息&#xff0c;而是等待一段时间后&#xff0c;消费者才可以从这个队列中拿到消息进行消费 2.应用场景 延迟队列的应用场景很多&#xff0c;…

flutter开发-figma交互设计图可以转换为flutter源代码-如何将设计图转换为flutter源代码-优雅草央千澈

flutter开发-figma交互设计图可以转换为flutter源代码-如何将设计图转换为flutter源代码-优雅草央千澈 开发背景 可能大家听过过蓝湖可以转ui设计图为vue.js&#xff0c;react native代码&#xff0c;那么请问听说过将figma的设计图转换为flutter源代码吗?本文优雅草央千澈带…

当设置dialog中有el-table时,并设置el-table区域的滚动,看到el-table中多了一条横线

问题&#xff1a;当设置dialog中有el-table时&#xff0c;并设置el-table区域的滚动&#xff0c;看到el-table中多了一条横线&#xff1b; 原因&#xff1a;el-table有一个before的伪元素作为表格的下边框下&#xff0c;初始的时候已设置&#xff0c;在滚动的时候并没有重新设置…

SQL-杂记1

PIVOT的使用: 行转列IIF()的使用:IIF( boolean_expression, true_value, false_value)多个字段使用MX()函数 SELECTD.ID,字段1,字段2,字段3,字段4,字段5,X.MinDateValue FROM 表名 D WITH(NOLOCK) OUTER APPLY (SELECT MIN(DateValue) AS MinDateValueFROM (VALUES (字段1),(字…

代理模式实现

一、概念&#xff1a;代理模式属于结构型设计模式。客户端不能直接访问一个对象&#xff0c;可以通过代理的第三者来间接访问该对象&#xff0c;代理对象控制着对于原对象的访问&#xff0c;并允许在客户端访问对象的前后进行一些扩展和处理&#xff1b;这种设置模式称为代理模…

windows 搭建flutter环境,开发windows程序

环境安装配置&#xff1a; 下载flutter sdk https://docs.flutter.dev/get-started/install/windows 下载到本地后&#xff0c;随便找个地方解压&#xff0c;然后配置下系统环境变量 编译windows程序本地需要安装vs2019或更新的开发环境 主要就这2步安装后就可以了&#xff0…

Redis系列之底层数据结构字典Dict

Redis系列之底层数据结构字典Dict Dict数据结构 Dict是Redis数据结构中使用最为频繁的复合型数据结构&#xff0c;本质上是一个哈希表 查看redis6.0版本的源码&#xff0c;链接&#xff1a;https://github.com/redis/redis/blob/6.0/src/dict.h 哈希表的结构定义&#xff1…

【Azure 架构师学习笔记】- Azure Function (2) --实操1

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Function 】系列。 接上文【Azure 架构师学习笔记】- Azure Function (1) --环境搭建和背景介绍 前言 上一文介绍了环境搭建&#xff0c;接下来就在本地环境下使用一下。 环境准备 这里我下载了最新的VS studio&…

Vue3中ref和reactive的区别

在 Vue 3 中&#xff0c;ref 和 reactive 都是用于响应式编程的 API&#xff0c;但它们有不同的使用场景和行为。以下是它们之间的区别&#xff1a; 1. ref 用途&#xff1a;用于创建基本数据类型&#xff08;如字符串、数字、布尔值&#xff09;或对象的响应式引用。数据类型…

简明docker快速入门并实践方法

简明docker快速入门并实践方法 前言&#xff1a;1. 什么是Docker&#xff1f;2. Docker的基本概念3. 安装配置Docker4. Docker基本命令&#xff1a;5. 简单实践&#xff1a;拉取Nginx镜像-自定义配置-推送镜像步骤 1&#xff1a;拉取Nginx镜像步骤 1.5&#xff08;可选&#xf…

【NextJS】PostgreSQL 遇上 Prisma ORM

NextJS 数据库 之 遇上Prisma ORM 前言一、环境要求二、概念介绍1、Prisma Schema Language&#xff08;PSL&#xff09; 结构描述语言1.1 概念1.2 组成1.2.1 Data Source 数据源1.2.2 Generators 生成器1.2.3 Data Model Definition 数据模型定义字段(数据)类型和约束关系&…

左神算法基础提升--3

文章目录 Manacher 算法经典算法Manacher算法原理 单调栈或单调队列 Manacher 算法 经典算法 在每学习Manacher算法之前我们可能会使用一种比较经典暴力的算法&#xff1a;遍历str字符串&#xff0c;将字符串中的每个字符作为对称点&#xff0c;向两边扩散找到回文字段&#x…