下拉选择

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.get("https://www.xxxxx.com/")
sleep(2)
driver.find_elements_by_tag_name('option')[2].click()
# 通过标签名定位到 option 标签,选择第三个,第一个下标为 0
driver.find_element_by_css_selector("[value='3']").click()
# 通过 css 定位属性定位

通过Select类定位

# 通过Select类定位
from selenium import webdriver
from selenium.webdriver.support.ui import Select
from time import sleep driver = webdriver.Chrome()
driver.get("http:\\www.xxxx.com")
select = Select(driver.find_element_by_css_selector("[name='CookieDate']"))
# 定位到所有的选项列表
select.select_by_index('') # 根据索引定位,从 0 开始
sleep(2)
select.select_by_visible_text("一年")
# 根据看的见的文本定位
select.select_by_value('') # 根据 value 值定位
sleep(2)
driver.quit()

栗子;

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>下拉框</title> </head>
<body>
<select name="fruit" size="1">
<option id="peach" value="taozi">桃子</option>
<option id="watermelon" value="xigua">西瓜</option>
<option id="orange" value="juzi">橘子</option>
<option id="kiwifruit" value="mihoutao">猕猴桃</option>
<option id="matbush" value="shanzha">山楂</option>
<option id="litchi" value="lizhi">荔枝</option> </select> </body>
</html>
遍历所有选项并打印选项显示的文本和选项值

from selenium import webdriver
import unittest
import time class Test_SelectText(unittest.TestCase):
def test_getSelectText(self): url = '01.html'
self.driver = webdriver.Chrome()
self.driver.get(url)
# 找到下拉框
select = self.driver.find_element_by_name('fruit')
# 找到所有的option
all_options = select.find_elements_by_tag_name('option')
for option in all_options:
print('选项显示的文本:', option.text)
print('选项值为:', option.get_attribute("value"))
# 找到一个选择一个
option.click()
time.sleep(2) test1 = Test_SelectText()
test1.test_getSelectText()

结果:

选项显示的文本: 桃子
选项值为: taozi
选项显示的文本: 西瓜
选项值为: xigua
选项显示的文本: 橘子
选项值为: juzi
选项显示的文本: 猕猴桃
选项值为: mihoutao
选项显示的文本: 山楂
选项值为: shanzha
选项显示的文本: 荔枝
选项值为: lizhi

通过索引定位

from selenium import webdriver
import unittest
from selenium.webdriver.support.ui import Select class Test_SelectText(unittest.TestCase):
def test_getSelectText(self): url = '01.html'
self.driver = webdriver.Chrome()
self.driver.get(url)
# 使用xpath定位方式获取select页面元素对象
select_element = Select(self.driver.find_element_by_xpath('//select'))
# 打印默认选中项的文本
print(select_element.first_selected_option.text)
# 获取所有选择项的页面元素对象
all_options = select_element.options
# 打印选项总个数
print(len(all_options))
if all_options[1].is_enabled() and not all_options[1].is_selected():
# 通过序号选中第二个元素,序号从0开始
select_element.select_by_index(1)
# 打印已选中的文本
txt = select_element.all_selected_options[0].text
print(txt)
# 断言当前选中的文本是否是西瓜
self.assertEqual(txt, '西瓜') test1 = Test_SelectText()
test1.test_getSelectText()

结果:

桃子
6
西瓜

根据文本获取

from selenium import webdriver
import unittest
from selenium.webdriver.support.ui import Select class Test_SelectText(unittest.TestCase):
def test_getSelectText(self):
url = '01.html'
self.driver = webdriver.Chrome()
self.driver.get(url)
# 使用xpath定位方式获取select页面元素对象
select_element = Select(self.driver.find_element_by_xpath('//select'))
# 打印默认选中项的文本
print(select_element.first_selected_option.text)
# 获取所有选择项的页面元素对象
all_options = select_element.options
# 打印选项总个数
print(len(all_options))
select_element.select_by_visible_text('猕猴桃')
txt = select_element.all_selected_options[0].text
print(txt)
# 断言当前选中的文本是否是猕猴桃
self.assertEqual(txt, '猕猴桃') test1 = Test_SelectText()
test1.test_getSelectText()

结果:

桃子
6
猕猴桃

根据value

from selenium import webdriver
import unittest
import time
from selenium.webdriver.support.ui import Select class Test_SelectText(unittest.TestCase):
def test_getSelectText(self):
url = '01.html'
self.driver = webdriver.Chrome()
self.driver.get(url)
# 使用xpath定位方式获取select页面元素对象
select_element = Select(self.driver.find_element_by_xpath('//select'))
# 打印默认选中项的文本
print(select_element.first_selected_option.text)
# 获取所有选择项的页面元素对象
all_options = select_element.options
# 打印选项总个数
print(len(all_options))
select_element.select_by_value('shanzha')
txt = select_element.all_selected_options[0].text
print(txt)
# 断言当前选中的文本是否是山楂
self.assertEqual(txt, '山楂') test1 = Test_SelectText()
test1.test_getSelectText()

select_element.all_selected_options属性获取的是所有被选中项的对象组成的列表对象

selenium--单选下拉列表的更多相关文章

  1. 自动化测试基础篇--Selenium单选框(Radio)复选框(CheckBox)

    摘自:https://www.cnblogs.com/sanzangTst/p/7686602.html 一.什么是单选框.复选框? 二.单选框:radio 三.复选框:checkbox 四.判断是否 ...

  2. 自动化测试-15.selenium单选框与复选框状态判断

    本篇主要介绍单选框和复选框的操作 一.认识单选框和复选框 1.先认清楚单选框和复选框长什么样 2.各位小伙伴看清楚哦,上面的单选框是圆的:下图复选框是方的,这个是业界的标准,要是开发小伙伴把图标弄错了 ...

  3. 小物件之select单选下拉列表

    有时候在控制器中做了一个数组 然后需要在模板view中循环 同时还需要判断是否有选中的值,就会造成很多开始闭合标签 以前都是这样写 这样实在太繁琐了,不如封装一个小物件 封装函数如下: 代码如下: f ...

  4. Python3 Selenium自动化web测试 ==> 第三节 常用WebDriver API使用示例上(24个API)

    前置步骤: 安装selenium,chrome驱动,Python3.6 学习目的: 常见API的使用 涉及的API: step1: 访问一个网址 step2: 网页的前进和后退 step3: 刷新当前 ...

  5. Selenium WebDriver 常用API

    public class Demo1 { WebDriver driver; @BeforeMethod public void visit(){ //webdriver对象的声明 System.se ...

  6. Selenium2学习-014-WebUI自动化实战实例-012-Selenium 操作下拉列表实例-div+{js|jquery}

    之前已经讲过了 Selenium 操作 Select 实现的下拉列表:Selenium2学习-010-WebUI自动化实战实例-008-Selenium 操作下拉列表实例-Select,但是在实际的日 ...

  7. Selenium2学习-010-WebUI自动化实战实例-008-Selenium 操作下拉列表实例-Select

    此文主要讲述用 Java 编写 Selenium 自动化测试脚本编写过程中,对下拉列表框 Select 的操作. 下拉列表是 Web UI 自动化测试过程中使用率非常高的,通常有两种形式的下拉列表,一 ...

  8. selenium常用API实例

    1.访问网页地址 driver.get( url ); driver.navigate( ).to( url ); 2.访问网页前进.后退 driver.navigate( ).forward( ); ...

  9. selenium面试题

    selenium中如何判断元素是否存在? selenium中没有提供原生的方法判断元素是否存在,一般我们可以通过定位元素+异常捕获的方式判断. # 判断元素是否存在 try: dr.find_elem ...

  10. python+selenium面试题

    selenium中如何判断元素是否存在? selenium中没有提供原生的方法判断元素是否存在,一般我们可以通过定位元素+异常捕获的方式判断. # 判断元素是否存在 try: dr.find_elem ...

随机推荐

  1. 大数据基础总结---MapReduce和YARN技术原理

    Map Reduce和YARN技术原理 学习目标 熟悉MapReduce和YARN是什么 掌握MapReduce使用的场景及其原理 掌握MapReduce和YARN功能与架构 熟悉YARN的新特性 M ...

  2. React学习之路之创建项目

    React 开发环境准备 IDE工具 visual studio code 开发环境 开发环境需要安装nodejs和npm,nodejs工具包含了npm. nodejs下载官网:https://nod ...

  3. MongoDB下载+安装+配置+错误解决方法

    下载 官网下载: https://www.mongodb.com/download-center/community Server=>Download 安装 下载完成后安装 建议下载根目录(下过 ...

  4. disconf的简单使用与远程配置更改为使用本地配置

    这几天因为阿里云迁移到腾讯云的原因,原来服务器上的disconf不再使用了.在这段时间里,系统出现的bug很难寻找原因(项目起不来),现在想要把disconf远程配置更改成直接使用本地配置.首先,了解 ...

  5. saltstack的简单搭建

    环境; centos 7     192.168.10.10    master centos 7     192.168.10.129  minion 1.为了方便关闭防火墙 [root@local ...

  6. Composer安装laravel框架

    一.打开CMD,进入想安装的目录,输入如下图所示,安装一个blog的项目: 二.进入指定目录即可看到生成的blog项目,如下图:

  7. 关于less的一些入门用法

    less 变量(Variables) @nice-blue: #5B83AD; @light-blue: @nice-blue + #111; #header { color: @light-blue ...

  8. 如何修改被readonly修饰的属性

    结论: 1.用KVC改变只读属性的值: 2.若禁止KVC方式修改只读属性的值,可在对应类重写类方法 // 该方法默认返回YES. 即在不存在满足条件的存取方法时,允许直接访问属性对应的实例变量+ (B ...

  9. Linux从入门到放弃、零基础入门Linux(第二篇):在虚拟机vmware中安装linux(一)超详细手把手教你安装centos分步图解

    一.Vmware vmware介绍:VMware,Inc. (Virtual Machine ware)是一个“虚拟PC”软件公司,提供服务器.桌面虚拟化的解决方案.其虚拟化平台的产品包括播放器:它能 ...

  10. ubuntu16.04 共享文件夹之后 /mnt/hgfs目录下没有显示共享的文件夹

    root权限执行: apt-get install open-vm-tools vmhgfs-fuse .host:/ /mnt/hgfs