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

时间: 2024-10-07 04:05:23

python自动化测试应用-第7篇(WEB测试)--Selenium进阶篇的相关文章

Web测试Selenium:如何选取元素

Web测试工具Selenium:如何选取元素 2009-02-17 23:23 by 敏捷的水, 5372 阅读, 22 评论, 收藏, 编辑 selenium是一个非常棒的Web测试工具,他对Ajax支持非常好,本人强烈推荐. 测试里很重要的一部,就是定位页面的元素,selenium提供如下强大的定位元素的方法. id=id name=name dom=javascriptExpression xpath=xpathExpression link=textPattern css=cssSele

Python之路【第十六篇续】Django进阶篇

Django请求生命周期 首先:对于所有的web框架来说本质就是一个socket服务端,浏览器是socket客户端 路由系统 在Django的urls中我们可以根据一个URL对应一个函数名来定义路由规则如下: from cmdb import views urlpatterns = [ url(r'^login/$', views.login), url(r'^index/$', views.index), url(r'^lists/$', views.lists), url(r'^add/$'

selenium + python自动化测试unittest框架学习(一)selenium原理及应用

unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻.unittest框架学习需要掌握以下知识点: (1)Selenium原理及工具使用 (2)webdriver元素定位,id,name,class name,css seletor,xpath (3)python语言基础,模块,参数化,语言,装饰器 (4)unittest框架认识及学习:模块化,断言,参数化,数

python 学习笔记十二之 html基础(进阶篇)

HTML 超级文本标记语言是标准通用标记语言下的一个应用,也是一种规范,一种标准,它通过标记符号来标记要显示的网页中的各个部分.网页文件本身 是一种文本文件,通过在文本文件中添加标记符, 可以告诉浏览器如何显示其中的内容(如:文字如何处理,画面如何安排,图片如何显示等).浏览器按顺序阅读 网页文件,然后根据标记符解释和显示其标记的内容,对书写出错的标记将不指出其错误, 且不停止其解释执行过程,编制者只能通过显示效果来分析出错原因和出 错部位.但需要注意的是,对于不同的浏览器,对同一标记符可能会有

[Python]学习基础篇:函数的进阶篇

对于函数大家都熟知不过了,但是对于一些函数还是费力的理解,下来我们来看看Python自带的一些函数,在此之前,还是请大家了解什么是高阶函数. 高阶函数:函数中的高阶函数 map()函数 格式:map(func,seq) 返回值:list map函数的作用是将参数函数func作用于seq中的每一个元素,每个元素产生的结果存放进list中. 例如:我们以函数func=x+x*x为例,作用于序列[1,2,3,4,5,6,7,8]上 !/bin/python def func(x):     retur

Web框架django进阶篇

分页 一.Django内置分页 from django.shortcuts import render from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger L = [] for i in range(999): L.append(i) # 模拟数据库 生成数据 def index(request): current_page = request.GET.get('page') # 通过get请求得到当前

python 自动化测试

安装selenium 安装命令: pip install selenium 测试 打开一款Python编辑器,默认Python自带的IDLE也行.创建 baidu.py文件,输入以下内容: from selenium import webdriver driver = webdriver.Chrome() driver.get('https://www.baidu.com') print(driver.title) driver.quit() 如果执行报错, 请看下面 selenium3 浏览器

selenium + python自动化测试unittest框架学习(二)

1.unittest单元测试框架文件结构 unittest是python单元测试框架之一,unittest测试框架的主要文件结构: File >report >all_case.py >test_case >__init__.py >test_case1..... >public >__init__.py >login.py >loginout.py test_case文件夹主要存放测试用例,且测试用例命名以test_开头 public文件夹是test

第一篇 用于测试使用

第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用第一篇 用于测试使用