轻松自动化---selenium-webdriver(python) (四)

https://www.cnblogs.com/fnng/p/3190966.html

 

http://www.testclass.net/  测试教程网,专业的selenium 学习网站。

本节要解决的问题:

如何定位一组元素?

 

场景

从上一节的例子中可以看出,webdriver可以很方便的使用findElement方法来定位某个特定的对象,不过有时候我们却需要定位一组对象,

这时候就需要使用findElements方法。

 

定位一组对象一般用于以下场景:

· 批量操作对象,比如将页面上所有的checkbox都勾上

· 先获取一组对象,再在这组对象中过滤出需要具体定位的一些对象。比如定位出页面上所有的checkbox,然后选择最后一个

复制代码
<html><head><meta http-equiv="content-type" content="text/html;charset=utf-8" /><title>Checkbox</title><script type="text/javascript" async="" src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script><link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" /><script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script></head><body><h3>checkbox</h3><div class="well"><form class="form-horizontal"><div class="control-group"><label class="control-label" for="c1">checkbox1</label><div class="controls"><input type="checkbox" id="c1" /></div></div><div class="control-group"><label class="control-label" for="c2">checkbox2</label><div class="controls"><input type="checkbox" id="c2" /></div></div><div class="control-group"><label class="control-label" for="c3">checkbox3</label><div class="controls"><input type="checkbox" id="c3" /></div></div>    <div class="control-group"><label class="control-label" for="r">radio</label><div class="controls"><input type="radio" id="r1" /></div></div><div class="control-group"><label class="control-label" for="r">radio</label><div class="controls"><input type="radio" id="r2" /></div></div></form></div></body>
</html>
复制代码

将这段代码保存复制到记事本中,将保存成checkbox.html文件。(注意,这个页面需要和我们的自动化脚本放在同一个目录下

 

 

 

第一种方法:

通过浏览器打个这个页面我们看到三个复选框和两个单选框。下面我们就来定位这三个复选框。

复制代码
# -*- coding: utf-8 -*-
from selenium import webdriver
import time
import osdr = webdriver.Firefox()
file_path =  'file:///' + os.path.abspath('checkbox.html')
dr.get(file_path)# 选择页面上所有的input,然后从中过滤出所有的checkbox并勾选之
inputs = dr.find_elements_by_tag_name('input')
for input in inputs:if input.get_attribute('type') == 'checkbox':input.click()
time.sleep(2)dr.quit()
复制代码

你可以试着把input.get_attribute('type') == 'checkbox' 中的checkbox 变成radio ,那这个脚本定位的会是两个单选框。

 

第二种定位方法:

复制代码
# -*- coding: utf-8 -*-
from selenium import webdriver
import time
import osdr = webdriver.Firefox()
file_path =  'file:///' + os.path.abspath('checkbox.html')
dr.get(file_path)# 选择所有的checkbox并全部勾上
checkboxes = dr.find_elements_by_css_selector('input[type=checkbox]')
for checkbox in checkboxes:checkbox.click()
time.sleep(2)# 打印当前页面上有多少个checkbox
print len(dr.find_elements_by_css_selector('input[type=checkbox]'))
time.sleep(2)dr.quit()
复制代码

第二种写法与第一种写法差别不大,都是通过一个循环来勾选控件;如果你学过上一章的话,细心的你一定发现用的定位函数不一样,

第一种用的name ,第二种用的CSS 。

 

 如何去掉勾选:

还有一个问题,有时候我们并不想勾选页面的所有的复选框(checkbox),可以通过下面办法把最后一个被勾选的框去掉。如下:

复制代码
# -*- coding: utf-8 -*-
from selenium import webdriver
import time
import osdr = webdriver.Firefox()
file_path =  'file:///' + os.path.abspath('checkbox.html')
dr.get(file_path)# 选择所有的checkbox并全部勾上
checkboxes = dr.find_elements_by_css_selector('input[type=checkbox]')
for checkbox in checkboxes:checkbox.click()
time.sleep(2)# 把页面上最后1个checkbox的勾给去掉
dr.find_elements_by_css_selector('input[type=checkbox]').pop().click()
time.sleep(2)dr.quit()
复制代码

其实,去掉勾选表也逻辑也非常简单,就是再次点击勾选的按钮。可能我们比较迷惑的是如何找到“最后一个”按钮。pop() 可以实现这个功能。

好吧!在web自动化的学习过程中,我们必须要知道一些前端的东西,这里扩展一下:

http://www.w3school.com.cn/js/jsref_pop.asp

 

 

尝试

把find_elements_by_css_selector('input[type=checkbox]').pop().click() 中的checkbox 变成radio 会是什么效果,自己尝试一下吧!

转载于:https://www.cnblogs.com/yuer20180726/p/10813346.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569467.shtml

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

相关文章

如何用CSS画一个三角形

border-left-color: border-top-width:中心距顶部距离 .userCard .welcome .triangle{ border: 8px solid transparent;width: 0px;height: 0px;border-left-color: #E8676B;border-top-width: 0; } 结果 → 这篇博客很清楚&#xff0c;可借助参考&#xff1a;https://…

CSS hr修改样式

hr 默认样式 若加上这样CSS hr{height: 0;border: none;border-top: 1px solid red; } 会变为

CSS height高度 和 width宽度

1、不到情非得已不要用height&#xff0c;height是bug的来源 2、内联元素的高度由 line-height 决定 3、块级元素的高度由 其内部文档流元素的高度总和决定 文档流&#xff1a;文档内元素的流动方向 4、max-width 是最大宽度&#xff0c;可以自适应&#xff0c;若屏幕小…

scrapy框架的日志等级和请求传参

Scrapy的日志等级 - 在使用scrapy crawl spiderFileName运行程序时&#xff0c;在终端里打印输出的就是scrapy的日志信息。- 日志信息的种类&#xff1a;ERROR &#xff1a; 一般错误WARNING : 警告INFO : 一般的信息DEBUG &#xff1a; 调试信息- 设置日志信息指定输出&#x…

绝对定位absolute、相对定位relative(脱离文档流)

1、脱离文档流&#xff0c;&#xff1a;父元素高度不再包含文档流高度 position&#xff1a;absolute 子元素 position&#xff1a;relative 父元素&#xff0c; 子元素相对于祖先中的第一个relative定位&#xff0c;用到的 top:0; left:0; 不然出bug 2、相对于屏幕…

第32月第8天 打包 Framework 时使用 CocoaPods 引入第三方库的方法

1. 但是可以发现打包完后的 .framework 包里面是没有 CocoaPods 集成的第三方库的&#xff0c;所以在使用 .framework 包时&#xff0c;工程中必须也要集成 .framework 包中用到的第三方库&#xff0c;否则会找不到文件而报错。 https://www.cnblogs.com/nelsen-chen/p/9353520…

CSS 加过渡效果transition

transition: box-shadow 0.3s; 给按钮加效果 transition: all 0.7s; 给进度条

php后端语言的基本语法

<?php$num 1;//php中定义一个变量echo $num;//php中打印一个值&#xff08;与console。log类似&#xff09;$arr array(1,2,3,4,5,6,7,89);//在php中定义一个数组//echo $arr;php中使用echo不能输出集合&#xff08;数组与对象&#xff09;&#xff0c;//必须采用print_r…

CSS居中问题

1.左浮后&#xff0c;想居中&#xff1a; 给他“爸爸”居中&#xff0c;如果没有宽度&#xff0c;不能用 margin&#xff1a;0 auto;可以用text-align&#xff1a;center&#xff1b; 2.继1&#xff0c;如果“爸爸”也没有确定的宽&#xff0c;想变窄 “爸爸”只能也变成 di…

12-order by和group by 原理和优化 sort by 倒叙

原理和优化 groupBy分组&#xff1f;会造成一个数据倾斜 1.解决方案&#xff1a;将输入在map端进行部分的打乱重分 set hive.groupby.skewindatatrue; 2.在map到reduce端的时候设置combiner进行合并 set hive.map.aggrtrue; 3.在combiner进行合并的时候要知道数据量的大小&…

内联元素(display:inline-block)注意事项

1.内联元素margin的上下没有用&#xff0c;加入 display:inline-block 后&#xff0c;才有用&#xff1b; 不是block块级元素了&#xff0c;那么想居中&#xff0c;用 margin&#xff1a;0 auto; 没用了&#xff0c; 那想居中&#xff0c;在他“父亲”加上 text-align&#x…

多个excel文件内容合并到一个excel文件的多个sheet的小程序

# -*- coding:utf-8 -*-import xlrd, xlsxwriter# 待合并excelallxls ["D:\\excelcs\\***.xlsx"]allxls1 ["D:\\excelcs\\***.xlsx"]allxls2 ["D:\\excelcs\\***.xlsx"]#print(allxls[0:2])# 目标excelend_xls "D:\\excelcs\\***.xlsx&…

【编程训练-考研上机模拟】综合模拟2-2019浙大上机模拟(晴神)

A - next[i] Problem Description 在字符串匹配的KMP算法中有一个重要的概念是next数组&#xff0c;求解它的过程让不少同学伤透了心。next数组的直接语义其实是&#xff1a;使“长度为L的前缀”与“长度为L的后缀”相同的最大L&#xff0c;且满足条件的前后缀不能是原字符串本…

CSS常用工具

wall haven 墙纸 CSS tricks shape 用CSS作图 iconfont.cn 小图标工具网站&#xff0c;&#xff08;添加至项目→symbol→查链接→生成代码→<script>→使用帮助&#xff09; CSS3 linear gradient &#xff08;generator&#xff09; 线性渐变工具 CSS animation…

CSS li 一半左浮一半右浮

.skills >ol li{float: left; 左浮width: 48%;margin-bottom: 40px; } .skills >ol li:nth-child(even){ //even 偶数 odd 奇数float: right; 右浮 }另一种 .skills >ol li:nth-child(1){ //第一个margin-left: 0; }.skills >ol li:first-child{ //…

addEventListener事件委托

什么是事件委托&#xff1a;通俗的讲&#xff0c;事件就是onclick&#xff0c;onmouseover&#xff0c;onmouseout&#xff0c;等就是事件&#xff0c;委托呢&#xff0c;就是让别人来做&#xff0c;这个事件本来是加在某些元素上的&#xff0c;然而你却加到别人身上来做&#…

HTML常遇问题

1、span 里面套 div 会有问题&#xff0c;可以套 span&#xff0c;再加语句 display:block; 相当于套了div 2. 外部不能加padding&#xff0c;所以可以再里层加 div&#xff0c;在加padding可以了 3、display:block; display:inline-block; 让border将它们包住 4、*{ …

bzoj3771:Triple

传送门 生成函数 设生成函数\(f(x)\)&#xff0c;可以将系数定为选的方案数&#xff0c;指数定为代价 那么\[ f(x)\sum_{i1}^{n}x^{w_i} \] 然后答案就是\(f^3(x)f^2(x)f(x)\)然后去掉重复的情况 然后我们设\[ A(x)\sum_{i1}^{n}x^{2w_i}\\ B(x)\sum_{i1}^{n}x^{3w_i} \] 重复的…

CSS图片设置

1、background-position: center center; 图片居中 background-size: cover; 让图片自适应&#xff0c;按比例缩放 2、加背景色mask&#xff0c;面罩&#xff1a; background: rgba(0, 0, 0, 0.7); 宽度不要写&#xff0c;自适应的 3. 图片的宽度&#xff0c;最好先规定好&…

sqlserver——视图

数据库中的视图是一个虚拟表。同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据&#xff0c;行和列数据用来自由定义视图和查询所引用的表&#xff0c;并且在引用视图时动态产生。本篇将通过一些实例来介绍视图的概念&#xff0c;视图的作用&#xff0c;创建视图…