Selenium4+Python3系列(八) - Cookie、截图、单选框及复选框处理、富文本框、日历控件操作
我所在的城市昨天出了近20+的阳性案例,但这丝毫没有 “影响” 到996的工作时间,当然,也没有影响到我想继续更新文章的决心。
一、cookie常用操作入门
上一篇有写过关于cookie的实战案例,个人觉得没有很好地照顾到入门同学的感受,所以就又更新了关于cookie的基本使用操作。
1、获取所有cookie信息
示例代码:
cookies = driver.get_cookies()
for cookie in cookies:
#### 遍历cookie
print(cookie)
print('集合长度:' + str(len(cookies)))
2、删除所有cookie信息
示例代码:
driver.delete_all_cookies()
cookies = driver.get_cookies()
print('删除后cookies集合长度:' + str(len(cookies)))
3、添加cookie
和JSON很像,必须有name和value值,python叫字典,示例代码:
cookie = {'name': 'login', 'value': 'true'}
driver.add_cookie(cookie)
4、获取指定名称的cookie信息
示例代码:
login_cookie = driver.get_cookie('login')
print('取出刚添加的cookie值: ' + str(login_cookie))
5、删除指定名称的cookie信息
示例代码:
driver.delete_cookie("login")
cookies = driver.get_cookies()
#删除login后,应该就没cookie了
print(cookies)
二、截图操作
1、获取当前屏幕截图,使用完整路径,文件名以时间命名
示例代码:
nowTime = time.strftime("%Y%m%d%H%M%S")
driver.get_screenshot_as_file('%s.png' % nowTime)
2、保存屏幕截图
示例代码:
driver.save_screenshot("testbaidu.png")
3、获取当前屏幕截图base64编码字符串
示例代码:
driver.save_screenshot("testbaidu.png")
print(driver.get_screenshot_as_base64())
4、获取当前屏幕截图的二进制文件数据
示例代码:
print(driver.get_screenshot_as_png())
三、单选框及复选框处理
判断是否选中:is_selected()
,有时单选框、复选框会有默认选中的情况,那么有必要在操作单选框或者复选框的时候,先判断选项框是否为选中状态。使用element.is_selected()
来获取元素是否为选中状态,返回结果为布尔类型,如果为选中状态返回True
,如果未选中返回为False
。
至于操作就不必多说了,对大家来讲是So Easy
,就点击就可以了。
1、单选框
示例代码;
**# 获取第1个单选框李白元素对象
element = driver.find_element(By.CSS_SELECTOR,"[value='0']")
isSelected = element.is_selected()
# 查看李白是否被选中
if isSelected:
print('李白已被选中,你只能选下一个英雄了')
# 获取第3个单选框露娜元素对象
element = driver.find_element(By.CSS_SELECTOR,"[value='2']")
# 判断是否被选中
if not element.is_selected():
# 如果未被选中,就可以直接选了
element.click()**
2、复选框
具体实例代码如下:
# 获取第三个复选框公孙离元素对象
element = driver.find_element(By.NAME, "checkbox3")
isSelected = element.is_selected()
# 如果选中取消选中
if isSelected:
element.click()
# 全选操作
elements = driver.find_elements(By.CSS_SELECTOR, "[type='checkbox']")
# 遍历选项
for element in elements:
# 点击选中
element.click()
四、富文本框操作
1、什么是富文本编辑器?
富文本编辑器,Rich Text Editor, 简称 RTE, 是一种可内嵌于浏览器,所见即所得的文本编辑器。
具体长啥样,如下图:
2、通过键盘事件操作富文本
通过Tab键,先移到富文本框中,自己需要提前数好需要按几下tab,才能介入,多写几个tab,也无妨,因为只有进入富文本,tab相当于缩进了。
示例代码如下:
action=ActionChains(driver)
# 鼠标通过tab要先移到富文本框中(自己需要提前数好需要按几下tab,才能介入,多写几个tab,也无妨,因为只有进入富文本,tab相当于缩进了)
for i in range(1,18):
action.send_keys(Keys.TAB).perform()
time.sleep(1)
action.send_keys("欢迎关注公众号:软件测试君").perform()
3、通过进入iframe实现操作富文本
示例代码如下:
driver.implicitly_wait(30)
# 进入富文本编辑器
driver.switch_to.frame("ueditor_0")
time.sleep(2)
driver.find_element(By.CSS_SELECTOR, ".view").click()
time.sleep(2)
# 输入文字
driver.find_element(By.CSS_SELECTOR, "[contenteditable='true']").send_keys("欢迎关注公众号:软件测试君")
time.sleep(2)
# 选中全部
driver.find_element(By.CSS_SELECTOR, ".view").send_keys(Keys.CONTROL + "a")
time.sleep(2)
# 跳出富文本编辑器
driver.switch_to.default_content()
# 加粗操作
driver.find_element(By.CSS_SELECTOR,".edui-for-bold .edui-icon").click()
4、通过执行js实现富文本操作
示例代码如下:
driver.get("https:uutool.cn/ueditor/")
content = "欢迎关注公众号:软件测试君";
#ueditor_0为所在iframe的id
js = "document.getElementById('ueditor_0').contentDocument.write('" + content + "');"
driver.execute_script(js)
五、日历控件操作
思路:移除元素的readonly属性,然后执行输入操作
示例代码如下:
driver.get("https://kyfw.12306.cn/otn/index/init")
# 去掉元素的readonly属性
js = 'document.getElementById("train_date").removeAttribute("readonly");'
driver.execute_script(js)
# 用js方法输入日期
# js_value = 'document.getElementById("train_date").value="2022-11-24"'
# driver.execute_script(js_value)
# # # 清空文本后输入值
driver.find_element(By.ID,"train_date").clear()
driver.find_element(By.ID,"train_date").send_keys("2022-11-24")
写在最后
我也曾无数次问过自己,该不该继续坚持写文章努力更新下去?
也可以说,我曾动摇过,因为做公号迁移后,导致我文章阅读量及转载的严重下滑,这真的让我很难受。
回想当初做公号的初心,一是为了交友,找到一些志同道合的技术朋友一起学习,二是,写出来当做学习笔记,或者可以说是复习笔记。
但更多的可能是期待能得到更多正向反馈,因为能让我们自己一直持续做某一件事情的原因,多半是来自他人的认可,然后并尽量把这件事情做到更好。
有自己的目标,找到自己努力的方向及节奏,只管坚持去做好了,剩下的就交给时间吧!
我是六哥,请继续关注我,一直996工作制,更文稍慢,还请谅解,原创不易,不求打赏,只求转发!
Selenium4+Python3系列(八) - Cookie、截图、单选框及复选框处理、富文本框、日历控件操作的更多相关文章
- Selenium3自动化测试【28】单选框、复选框、下拉选择框
Html页面中的单选按钮.复选框.下拉框均可通过WebDriver实现操做.本节结合案例一起来看看WebDriver如何操做这些控件. 同步视频知识与系列知识内容,可关注:[公众号]:柒哥测试:[WX ...
- CSS学习笔记三:自定义单选框,复选框,开关
一点一点学习CCS,这次学习了如何自定义单选框,复选框以及开关. 一.单选框 1.先写好body里面的样式,先写几个框 <body> <div class="radio-1 ...
- 自动化测试-15.selenium单选框与复选框状态判断
本篇主要介绍单选框和复选框的操作 一.认识单选框和复选框 1.先认清楚单选框和复选框长什么样 2.各位小伙伴看清楚哦,上面的单选框是圆的:下图复选框是方的,这个是业界的标准,要是开发小伙伴把图标弄错了 ...
- 2.12 单选框和复选框(radiobox、checkbox)
2.12 单选框和复选框(radiobox.checkbox) 本篇主要介绍单选框和复选框的操作一.认识单选框和复选框 1.先认清楚单选框和复选框长什么样 2.各位小伙伴看清楚哦,上面的单选框是 ...
- Selenium2学习(十五)-- 单选框和复选框(radiobox、checkbox)
本篇主要介绍单选框和复选框的操作 一.认识单选框和复选框 1.先认清楚单选框和复选框长什么样 2.各位小伙伴看清楚哦,上面的单选框是圆的:下图复选框是方的,这个是业界的标准,要是开发小伙伴把图标弄错了 ...
- 微信小程序-修改单选框和复选框大小的方法
方法有两种: 一:采用css的zoom属性 zoom缩放会将元素保持在左上角,并且会有毛边,可能会稍稍改变元素原来的形状. 二:采用css3的transform:scale属性 zoom缩放会将元素保 ...
- HTML--使用单选框、复选框,让用户选择
在使用表单设计调查表时,为了减少用户的操作,使用选择框是一个好主意,html中有两种选择框,即单选框和复选框,两者的区别是单选框中的选项用户只能选择一项,而复选框中用户可以任意选择多项,甚至全选.请看 ...
- Selenium3+python自动化 单选框和复选框
一.认识单选框和复选框 1.先认清楚单选框和复选框长什么样 2.各位小伙伴看清楚哦,上面的单选框是圆的:下图复选框是方的,这个是业界的标准,要是开发小伙伴把图标弄错了,可以先抽他了. 二.radio和 ...
- jQuery获取单选框(复选框)选中的状态
jQuery 获取单选框(复选框)选中的状态 <input type="checkbox" name="" id="choose"/& ...
- vue.js实现单选框、复选框和下拉框
Vue.js可以很方便的实现数据双向绑定,所以在处理表单,人机交互方面具有很大的优势.下边以单选框.复选框和下拉框为例介绍他们在HTML和Vue.js中的具体实现方式. 一.单选框 在传统的HTM ...
随机推荐
- 助力培养高质量AI人才,璞公英乐学平台在日本深受好评!
璞公英乐学平台(原名"璞睿魔数")自进入日本市场以来,受到日本用户的广泛好评.近日,日本AI门户网站AIsmiley在发刊的杂志<AI人才育成指南>中对璞公英乐学平台做 ...
- SQL注入篇——sqli-labs各关卡方法介绍|1-65
主要是记下来了每关通过可以采用的注入方式,可能部分关卡的通关方式写的不全面,欢迎指出,具体的获取数据库信息请手动操作一下. 环境初始界面如下: sql注入流程语句: order by 3--+ #判断 ...
- jumpserver设置某个用户登陆后,直接进入指定的服务器,不需要通过导航web终端--我的资产--服务器一连串的展开
ssh jumpserverUsername@systemUsername@AssetIP@jumpserverHostIP -p2222 解释: - jumpserverUsername:登录 Ju ...
- 从 Yum 更新中排除特定/某些包的三种方法
方法 1:手动或临时用 yum 命令排除包 要排除单个包: # yum update --exclude=kernel 或者 # yum update -x 'kernel' 要排除多个包.以下命令将 ...
- Beats:使用Elastic Stack对Nginx Web服务器监控
- js基础知识--BOM
之前说过,在js的 运行环境为浏览器时,js就主要有三部分组成: ECMAScript核心语法.BOM.DOM.今天就和大家详细说一下BOM的一些基础知识. BOM BOM通常被称为浏览器对象模型,主 ...
- 【前端必会】不知道webpack插件? webpack插件源码分析BannerPlugin
背景 不知道webpack插件是怎么回事,除了官方的文档外,还有一个很直观的方式,就是看源码. 看源码是一个挖宝的行动,也是一次冒险,我们可以找一些代码量不是很大的源码 比如webpack插件,我们就 ...
- LeetCode - 数组的旋转总结
1. 数组的旋转总结 数组的旋转指的是将数组的最后若干个数提前到数组前面,数组的翻转指的是将数组的顺序颠倒.旋转可以通过多次翻转实现. 数组的翻转很简单,通过双指针来实现:交换数组的第一个数和最后一个 ...
- 微软出品自动化神器Playwright(Playwright+Java)系列(四) 之 浏览器操作
写在前面 今天是国庆节的最后一天,明天又要上班了,真的是感觉好像才开始放假一样,还是因为失恋没缓过来吗? 我的国庆七天 第1天,当了近半天的司机,陪家人去各大超市去购物,下午在家躺····· 第2-5 ...
- bootstrapValidator 参数校验框架
bootstrap:能够增加兼容性的强大框架. 因为项目需要数据验证,看bootstrapValidator 还不错,就上手一直,完美兼容,话不多说. 需要引用css: bootstrap.min.c ...