python自动化测试应用-第7篇(WEB测试)--Selenium进阶篇
篇7 python自动化测试应用-Selenium进阶篇
--lamecho
1.1概要
大家好!我是lamecho(辣么丑),本篇文章将是我们介绍selenium使用的最后一篇进阶篇,会给大家带来一些干货帮助大家能够处理在实战中碰到的实际问题。
1.2 selenium继续实战百度页面
我们继续以百度作为实战的对象。通过上一篇的讲解,我们大概知道了网页元素的基本知识和对一些常见元素类型的操作,比如按钮,input输入框,链接等其实只要大家仔细分析它的tagname(标签)就能很快的找到并进行输入或点击操作。那么今天我将进一步讲解有关网页或是浏览器的一些操作。比如接下来我们介绍的第一个新类型Select选择条。
1.Select和option选项
在页面如果碰到弹出的下拉选项该如何操作,如下图百度主页的搜索设置中的红框位置。
我们首先看看它的页面源码
# -*-encoding:utf-8 -*-
from selenium import webdriver
from selenium.webdriver.support.select import Select
from selenium.webdriver.common.action_chains import ActionChains
browser=webdriver.Firefox()
browser.maximize_window()
browser.get("https://www.baidu.com/")
browser.implicitly_wait(10)
el=browser.find_element_by_link_text(u'设置')
ActionChains(browser).move_to_element(el).release().perform()
browser.implicitly_wait(10)
browser.find_element_by_link_text(u'搜索设置').click()
browser.implicitly_wait(10)
sel=browser.find_element_by_id('nr')
Select(sel).select_by_value('50')
sleep(2)
Select(sel).select_by_index(1)
sleep(10)
browser.quit()
这里主要分析最后几行脚本,在开始我们首先要导入Select模块
from selenium.webdriver.support.select import Select
sel=browser.find_element_by_id('nr')
#通过id将找到的select赋值给sel
Select(sel).select_by_value('50')
#用Select(sel)转化sel为Select,然后就可以用Select的方法去做选择。常用的方法有两个select_by_value和select_by_index。这里要注意value值是标签里的value值不是text,index下标从0开始计数。
sleep(2)
Select(sel).select_by_index(1)
2.执行脚本命令
有时候selenium提供给我们的方法不足以完成一些复杂的操作,这时候我们可以借助脚本命令去在页面上完成相应的动作。比如说怎么操作浏览器的滚动条操作页面上划下划呢?
我们先来看看脚本执行的方法是怎么写的
js='window.scrollTo(0,document.body.scrollHeight);'#下划到页面底部
browser.execute_script(js)
我们要执行的js语句放到execute_script里就可以了,这里只是有关脚本的一个应用展示,其实通过脚本命令我们还可以干很多事情。这里就要大家去多了解一些javascript相关的一些知识。比如
‘var obj=document.getElementsByTagName(\"a\");return obj[3].text=500;’
将找到的a标签的text值修改成500,那么最后网页上对应的这个元素的text值会变成500。还有这样js="return document.readyState",将会返回当前网页的加载情况,依据脚本执行的返回值,我们可以判断页面是否加载完成。
3.iframe标签
当我们遇到这样的标签时,该怎么办呢?它类似与页面内嵌了一个页面,可以从上面的截图查看到这是百度地图的页面源码,在iframe框架中包含的是一个完整的html页面,这时我们要去在嵌套的框架页面上定位操作元素,其实也非常简单,我们只要将browser切换到这个框架页面中去就可以了,使用语句 browser.switch_to.frame(frame_ID)
frame_ID获取可以在元素iframe中的源码中获取它的id(在selenium的API介绍中可以通过id和name获取到iframe,但是实际当中name属性并不好用)。当我们在frame中操作完成后,要继续在原页面执行的话,需要使用语句
browser.switch_to_default_content()
也就是再切换回原页面内容。这里再说一种情况,如果我们遇到iframe框架的id是动态的,也就是每次页面加载都会动态指定id,我们可以在python中这样处理:
frame_ID=browser.find_element_by_tag_name('iframe').get_attribute('id')
browser.switch_to.frame(frame_ID)
这样写就不需要考虑iframe框架的id问题,因为我们也是动态获取当前页面的id值。
4.让页面执行键盘操作ActionChains
首先我们要导入一些新的包
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.common.keys import Keys
同样的在百度搜索框中输入,最后操作键盘的回车进行检索。
browser.implicitly_wait(10)
el=browser.find_element_by_id('kw')
ActionChains(browser).send_keys_to_element(el,'lamecho').key_down(Keys.ENTER).key_up(Keys.ENTER).perform()
主要看最后一行send_keys_to_element(el,'lamecho')向el元素中输入字符,紧接着key_down和key_up就是操作按下弹起Keys.ENTER(回车)。这样写是不是很方便,一行搞定几个动作。另外它也可以实现组合键的操作,只要我们将按键的key_down,key_up顺序写对就ok了。
5.浏览器的新标签
目前浏览器都会支持在一个窗口中打开多个页面,也就是我们常说的标签页。那么当我们在执行操作时,新的页面是在新的标签页中打开的,我们要怎么样去在新的页面中执行元素的查找呢?曾经在网络上看到过有网友是通过键盘的物理按键Ctrl+tab去切换到新标签,诚然我们看到页面是做了切换,但是这样我们是无法继续在这个新页面去做元素查找的,因为我们的browser还是在原页面,这个和frame切换一个道理。只有将我们的browser切换到新新页面,才能继续在新的页面里去查找元素。我们看在python脚本中怎么去做这样的操作。
browser.implicitly_wait(10)
browser.find_element_by_id('TANGRAM__PSP_8__userName').send_keys('test')
browser.find_element_by_id('TANGRAM__PSP_8__password').send_keys('test')
#browser.find_element_by_id('TANGRAM__PSP_8__submit').click()
browser.find_element_by_link_text(u'立即注册').click()
while 1:
h=browser.window_handles
if len(h)==2:
name=h[1]
break
sleep(1)
browser.switch_to_window(name)
browser.implicitly_wait(10)
browser.find_element_by_id('TANGRAM__PSP_3__verifyCode').send_keys('1234')
继续我们百度页面的实战,当我们打开登录框后,我们最后一步是点击的“登录”按键,我们将其注释掉,改成点击“立即注册”按键。实际执行是百度页面是在新的标签页面中打开的注册页面,接着往下看我们的脚本,使用到了循环去执行browser.window_handles,去查找浏览器窗口的handle,当新的标签打开后自然我们的窗口会变成两个,它的长度自然也就会等于2,跳出循环,然后我们再通过browser.switch_to_window(name),将我们的browser切换到新页面中继续我们的元素查找工作。大家执行一下效果是不是最后在校验码的input中输入了1234。
1.3 进阶篇—结束
Selenium的进阶篇终于完稿了,其实也就是讲述了实际项目中碰到的一点棘手问题,操作稍微复杂一些而已。而我在文章中所能涉及的内容其实在selenium的使用上所能涵盖的十之只有一二,大家要多多练习,共勉。
感谢大家耐心读完,我是lamecho辣么丑。
原创文章,转载请注明出处。新浪微博搜索 “lamecho好棒” 欢迎大家来撩。
微博:https://weibo.com/u/6017986584
博客:http://blog.sina.com.cn/u/6017986584
python自动化测试应用-第7篇(WEB测试)--Selenium进阶篇的更多相关文章
- Python爬虫小白入门(四)PhatomJS+Selenium第一篇
一.前言 在上一篇博文中,我们的爬虫面临着一个问题,在爬取Unsplash网站的时候,由于网站是下拉刷新,并没有分页.所以不能够通过页码获取页面的url来分别发送网络请求.我也尝试了其他方式,比如下拉 ...
- Web测试Selenium:如何选取元素
Web测试工具Selenium:如何选取元素 2009-02-17 23:23 by 敏捷的水, 5372 阅读, 22 评论, 收藏, 编辑 selenium是一个非常棒的Web测试工具,他对Aja ...
- 自动化测试(web测试selenium框架)
什么是selenium? 一个用于Web应用程序测试的工具直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括IE(7, 8, 9, 10, 11),Mozilla Firefox,Safa ...
- web自动化-selenium 入门篇
selenium安装介绍 selenium是web浏览器的自动化工具 官网:https://www.selenium.dev 构成: WebDriver: 浏览器提供的浏览器api来控制浏览器(模拟用 ...
- Python之路【第十六篇续】Django进阶篇
Django请求生命周期 首先:对于所有的web框架来说本质就是一个socket服务端,浏览器是socket客户端 路由系统 在Django的urls中我们可以根据一个URL对应一个函数名来定义路由规 ...
- 使用python爬虫抓站的一些技巧总结:进阶篇
Reference:http://python.jobbole.com/82000/ 一.gzip/deflate支持 现在的网页普遍支持gzip压缩,这往往可以解决大量传输时间,以VeryCD的主页 ...
- Powershell渗透测试系列–进阶篇
原文来自:https://bbs.ichunqiu.com/thread-41561-1-1.html i春秋作家:anyedt 0×00 引言 经过基础篇的学习我们已经对powershell有了一个 ...
- selenium + python自动化测试unittest框架学习(一)selenium原理及应用
unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻. ...
- Python爬虫小白入门(五)PhatomJS+Selenium第二篇
一.前言 前文介绍了PhatomJS 和Selenium 的用法,工具准备完毕,我们来看看如何使用它们来改造我们之前写的小爬虫. 我们的目的是模拟页面下拉到底部,然后页面会刷出新的内容,每次会加载10 ...
随机推荐
- maven项目无法查看方法
问题如图: 解决:
- linux codeblocks汉化
参考window汉化codeblocks,linux下有点麻烦,就是要找到codeblocks的文件安装在哪里.一般来说,linux下安装的软件大都在/usr/share/文件夹下,所以进入/usr/ ...
- [LeetCode] Trapping Rain Water II 题解
题意 题目 思路 我一开始想的时候只考虑到一个结点周围的边界的情况,并没有考虑到边界的高度其实影响到所有的结点盛水的高度. 我们可以发现,中间是否能够盛水取决于边界是否足够高于里面的高度,所以这必然是 ...
- kvm的sshd起不来
同事不知道在一台KVM虚拟机执行了chmod -R 777 / 将更目录中的所有文件的权限都改为777,重启该虚拟机之后发现该虚拟机登不上去了,来找我,我尝试重启了几次虚拟机之后,发现总是可以被pi ...
- vmware克隆之后网卡起不来的问题
问题: 克隆一台主机之后,改主机的网卡起不来,只有一个本地的回环地址网卡. 使用如下的命令都无效. /etc/init.d/network restart ifup eth0 原因: 这一vmware ...
- 在线阅读PDF文件js插件——pdf.js
最近接到一个需求大致是这样的,要求在移动端和pc端能够在线阅读pdf文件,类似百度文库的功能. 首先想到的就是插件,github(全球最大的男性交友网站- -恩)上一大堆啊,首先找到一个PDFobje ...
- PRINCE2重要性--光环国际培训
项目的重要性 答:对于当今的组织来说,一个关键的挑战,就是能够成功地平衡以下两个并存的.互相竞争的方面:保持现有的商业运营--盈利能力.服务质量.客户关系.品牌忠实度.生产效率.市场信心等,这些被称为 ...
- Linux环境下的IDE,极大提升编程效率
"一个真正的程序员是不用IDE(译者注:集成开发环境)的,他们都是用带着某某插件的文本编辑器来写代码."我们总能在某些地方听到此类观点.然 而,尽管越来越多的人同意这样的观点,但是 ...
- 微服务架构的简单实现-Stardust
微服务架构,一个当下比较火的概念了.以前也只是了解过这方面的概念,没有尝试过.想找找.NET生态下面是否有现成的实现,可是没找到,就花了大半个月的闲暇时间,遵循着易用和简单,实现了一个微服务框架,我叫 ...
- 【Electron】Electron开发入门(三):main process和web page 通信
一.main process 和 web page 通信 electron框架主进程(Main Process)与嵌入的网页(web page,也就是renderer process)之间的通信 Ma ...