页面中的<select></select>标签,就代表该元素是一个下拉菜单。

1、使用Selenium中的Select类来处理下拉菜单(推荐)

可以使用Select类中提供的方法来操作页面中的下拉菜单。

(1)操作步骤

# 1.导入包Select类
from selenium.webdriver.support.select import Select # 2.定位下拉菜单元素 # 3.把定位的下拉菜单元素存储到Select类中
select = Select(下拉菜单元素) # 4.1 通过value属性来选择,option标签的一个属性值
select.select_by_value('属性值') # 4.2 通过选项索引(index)值选择 索引从0开始
select_by_index(索引值) # 4.3 通过选项名称选择
select_by_visible_text(选择名称)

(2)示例

页面代码片段

<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
</head>
<body>
<select name="selecta" id="selectA">
<option value="bj">A北京</option>
<option value="sh">A上海</option>
<option value="gz">A广州</option>
<option value="cq">A重庆</option>
</select>
</body>
</html>

脚本代码:

"""
1.学习目标:
掌握selenium中Select类使用
2.语法(操作步骤)
2.1导入Select类
2.2 定位下拉框的select标签
2.3 使用Select类提供的方法选择选项
2.3.1 通过选项的value值选择
select_by_value("value属性值")
2.3.2 通过选项索引值选择 索引从0开始
select_by_index(索引值)
2.3.3 通过选项名称选择
select_by_visible_text(选择名称)
3.需求
在页面中,使用Select类操作下拉框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
from selenium.webdriver.support.select import Select # 2.打开浏览器
driver = webdriver.Chrome() # 3.打开页面
url = "file:///" + os.path.abspath("./3.html")
driver.get(url)
sleep(2)
# 4.使用Select类操作下拉框
# 4.1 定位下拉框标签
selectA = driver.find_element_by_id("selectA") # 4.2 通过Select类选择选项
# 创建下拉框对象
# Select(定位下拉框的元素--select标签元素)
select = Select(selectA) # 通过value值选择选项(选择上海)
select.select_by_value("sh")
sleep(2) # 通过index值选择选项,索引从0开始(选择广州)
select.select_by_index(2)
sleep(2) # 通过text值选择选项(选择北京)
select.select_by_visible_text("A北京")
sleep(2) # 5.关闭浏览器
driver.quit()

2、下拉菜单对象的其他操作(了解)

调用如下方法,选择下拉框中的选项

操作 说明
all_selected_options 查看所有已选
first_selected_option 查看第一个已选
is_multiple 查看是否是多选
options 查看选项元素列表

取消选择:

操作 说明
deselect_by_value() 通过option标签的value属性来选择
deselect_by_index() 通过选项索引(index)值选择 索引从0开始
deselect_by_visible_text() 通过选项名称选择

示例

同上边示例,具体看获得的select下拉菜单元素对象的操作。

# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
from selenium.webdriver.support.select import Select # 2.打开浏览器
driver = webdriver.Chrome() # 3.打开页面
url = "file:///" + os.path.abspath("./3.html")
driver.get(url)
sleep(2) # 4.使用Select类操作下拉框
# 4.1 定位下拉框标签
selectA = driver.find_element_by_id("selectA") # 4.2 通过Select类选择选项
# 创建下拉框对象
# Select(定位下拉框的元素--select标签元素)
select = Select(selectA) """
我们就以first_selected_option举个例子,
其他的操作同理,自己尝试。
"""
# 5.下拉框元素对象的操作
# 下拉框对象直接调用操作
# 5.1 打印下拉框第一个已选选项
print("打印第一个已选选项", select.first_selected_option) # 5.2 查看第一个已选选项对象的方法
print(dir(select.first_selected_option)) # 5.3 通过上一步,我们查看选项对象有一个text方法
# 是获取选项的名称
print(select.first_selected_option.text) # A北京 # 6.关闭浏览器
driver.quit()

3、通过元素二次定位方式操作下拉菜单(重点)

(1)了解元素二次定位

先定位下拉菜单,再定位菜单中的具体元素,对下拉菜单进行二次定位。

类似于XPathcss_selector层级定位。

在实际测试过程中,一个页面可能有多个属性基本相同的元素,如果要定位到其中的一个,这时候可以使用层级定位或者元素的二次定位。

即:先定位到父元素,然后再通过父元素定位子孙元素。

(2)示例:

页面代码片段

<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
</head>
<body>
<select name="selecta" id="selectA">
<option value="bj">A北京</option>
<option value="sh">A上海</option>
<option value="gz">A广州</option>
<option value="cq">A重庆</option>
</select>
</body>
</html>

脚本代码

"""
1.学习目标:
掌握二次定位的方法
2.语法(操作步骤)
2.1 定位父标签
2.2 通过父标签定位子标签
3.需求
在页面中,使用二次定位方法,操作下拉菜单
4.总结
二次定位:通过元素找另外元素。
和xpath,css_selector层级定位类似。 除了元素的基本操作外,元素也可以定位其他元素。
元素.click()/clear()/send_keys()/find_element_xxx 注意:二次定位不止使用在下拉菜单操作中。
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os # 2.打开浏览器
driver = webdriver.Chrome() # 3.打开页面
url = "file:///" + os.path.abspath("./3.html")
driver.get(url)
sleep(2) # 4.二次定位操作下拉菜单
# 4.1 先定位父级元素--select标签元素
select = driver.find_element_by_name("selecta") # 4.2 通过select标签元素定位option子标签
option = select.find_element_by_css_selector("option[value='gz']") # 4.3 点击选择的选项
option.click()
sleep(2) # 5.关闭浏览器
driver.quit()

『心善渊』Selenium3.0基础 — 13、Selenium操作下拉菜单的更多相关文章

  1. 『心善渊』Selenium3.0基础 — 24、Selenium的expected_conditions模块详细介绍

    目录 1.EC模块介绍 2.EC模块常用类 3.EC模块的使用 4.EC模块综合使用 (1)title_is(title)示例 (2)presence_of_element_located(locat ...

  2. 『心善渊』Selenium3.0基础 — 11、Selenium对元素常用操作

    目录 1.Selenium对元素常用操作 2.Selenium对元素的其他操作 1.Selenium对元素常用操作 操作 说明 click() 单击元素 send_keys() 模拟输入 clear( ...

  3. 『心善渊』Selenium3.0基础 — 12、Selenium操作鼠标和键盘事件

    目录 (一)对鼠标的操作 1.鼠标事件介绍 2.ActionChains 类鼠标操作的常用方法 3.perform()方法 4.鼠标事件操作步骤 5.示例 (1)右键单击.左键双击 (2)鼠标拖拽动作 ...

  4. 『心善渊』Selenium3.0基础 — 1、Selenium自动化测试框架介绍

    目录 1.Selenium介绍 2.Selenium的特点 3.Selenium版本说明 4.拓展:WebDriver与Selenium RC的区别 5.Webdriver工作原理 1.Seleniu ...

  5. 『心善渊』Selenium3.0基础 — 19、使用Selenium操作文件的上传和下载

    目录 1.Selenium实现文件上传 (1)页面中的文件上传说明 (2)文件上传示例 (3)总结 2.Selenium实现文件下载 (1)Firefox浏览器文件下载 1)操作步骤: 2)文件下载示 ...

  6. 『心善渊』Selenium3.0基础 — 20、Selenium对Cookie的操作

    目录 1.Cookie介绍 2.Session介绍 3.Cookie工作原理图解 4.Cookie内容参数说明 5.Selenium操作Cookie的API 6.Selenium操作Cookie的示例 ...

  7. 『心善渊』Selenium3.0基础 — 17、Selenium操作浏览器窗口的滚动条

    目录 1.为什么操作滚动条 2.Selenium如何操作滚动条 3.Selenium操作滚动条方法 4.操作滚动条示例 5.下拉至聚焦元素的位置 (1)实现步骤: (2)实现示例: 1.为什么操作滚动 ...

  8. 『心善渊』Selenium3.0基础 — 2、Selenium测试框架环境搭建(Windows)

    目录 1.浏览器安装 2.浏览器驱动下载 (1)ChromeDriver for Chrome (2)Geckodriver for Firefox (3)IEDriverServer for IE ...

  9. 『心善渊』Selenium3.0基础 — 3、使用Selenium操作浏览器对象的基础API

    目录 1.导入Selenium库 2.创建浏览器对象 3.浏览器窗口大小设置 4.浏览器位置设置 5.请求访问网址 6.浏览器页面前进.后退和刷新 7.关闭浏览器 相比于高大上的各种Selenium进 ...

随机推荐

  1. CentOS 7.6 操作系统 安装指导书 (鲲鹏920处理器) 01

    若需要手动调整预留内存大小,请参考如下配置进行调整. 以下以配置crashkernel为512M为例进行操作说明: 命令行执行命令vi /etc/default/grub,配置"crashk ...

  2. ARM64平台编译stream、netperf出错解决办法 解决办法:指定编译平台为alpha [root@localhost netperf-2.6.0]# ./configure –build=alpha

    ARM64平台编译stream.netperf出错解决办法 http://ilinuxkernel.com/?p=1738 stream编译出错信息: [root@localhost stream]# ...

  3. "sar"工具 利用率

    LTP--linux稳定性测试 linux性能测试 ltp压力测试   余二五 2017-11-14 16:20:00 浏览1172 linux 日志 配置 内存管理 测试 脚本 性能测试 压力测试 ...

  4. linux进阶之远程免密登录,动态添加磁盘及个别基础命令

    一. 免密登录(远程连接ssh) ssh IP   #连接登录到其它机 ssh 192.168.10.102 ssh IP "CMD"   #在其它机器上执行命令 yum -y i ...

  5. 聊聊 Spring 的 XML Schema 扩展机制的使用方式

    前言 在当前Java生态,Spring算的上是最核心的框架,所有的开发组件想要得到大范围更便捷的使用,都要和Spring进行整合,比如我们熟知的Mybatis.Dubbo等,以及内部封装的各类组件包括 ...

  6. 在vue中如何使用WebSocket 以及nginx代理如何配置WebSocket

    WebSocket WebSocket是一种网络传输协议,可在单个TCP连接上进行全双工通信.浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接,并进行双向数据传输. 浏览器支持情况 现 ...

  7. Scrum Master 生存指南

    近年来,出现了一批新兴且广受关注的岗位,以 Scrum Master 为典型代表.2018年,Scrum Master 的平均工资为98239美元.领英更是将其列为2019年最有前途的工作之一.但对于 ...

  8. 巧用 iLocker 清理恶意程序

    iLocker 作为 iGuard 网页防篡改系统的文件驱动过滤模块所衍生出来的独立应用,是一个文件防护工具,可以在文件系统驱动层检查文件操作,根据规则对文件操作进行放行或拦截,可以灵活细致地对文件访 ...

  9. 2021.5.23 noip模拟2(排序|划艇|放棋子)

    今天比昨天更惨,惨炸了 看到T1不会,跳!!! T2不会,再跳!!!! T3不会,后面没题了:::: 无奈无奈,重新看T1,然鹅时间已经过去了一个小时 然而我一想不出题来就抱着水瓶子喝水,然后跑厕所, ...

  10. 深入探索Glide图片加载框架:做了哪些优化?如何管理生命周期?怎么做大图加载?

    前言 Glide可以说是最常用的图片加载框架了,Glide链式调用使用方便,性能上也可以满足大多数场景的使用,Glide源码与原理也是面试中的常客. 但是Glide的源码内容比较多,想要学习它的源码往 ...