Selenium2+python自动化-操作浏览器基本方法

前言
  从这篇开始,正式学习selenium的webdriver框架。我们平常说的 selenium自动化,其实它并不是类似于QTP之类的有GUI界面的可视化工具,我们要学的是webdriver框架的API。本篇主要讲如何用Python调用webdriver框架的API,对浏览器做一些常规的操作,如打开、前进、后退、刷新、设置窗口大小、截屏、退出等操作。

一、打开网站
1.第一步:从selenium里面导入webdriver模块;
2.打开Firefox浏览器(Ie和Chrome对应下面的);
3.打开百度网址;

from selenium import webdriver  # 导入模块

driver = webdriver.Firefox()    # 火狐浏览器
# driver = webdriver.Chrome()   # 谷歌浏览器
# driver = webdriver.Ie()       # IE浏览器
driver.get("https://www.baidu.com/")

二、设置休眠
1.由于打开百度网址后,页面加载需要几秒钟,所以最好等到页面加载完成后再继续下一步操作;
2.导入time模块,time模块是Python自带的,所以无需下载;
3.设置等待时间,单位是秒(s),时间值可以是小数也可以是整数;

from selenium import webdriver
import time         # 导入时间模块
driver = webdriver.Firefox()    # 火狐浏览器
driver.get("https://www.baidu.com/")
time.sleep(1)   # 设置休眠时间(秒),也可以为小数

三、页面刷新
1.有时候页面操作后,数据可能没及时同步,需要重新刷新;
2.这里可以模拟刷新页面操作,相当于浏览器输入框后面的刷新按钮;

from selenium import webdriver
import time
driver = webdriver.Firefox()    # 火狐浏览器
driver.get("https://www.baidu.com/")
time.sleep(1)   # 设置休眠时间(秒)
driver.refresh()    # 刷新操作

四、前进和后退
1.当在一个浏览器打开两个页面后,想返回上一页面,相当于浏览器左上角的左箭头按钮;
2.返回到上一页面后,也可以切换到下一页,相当于浏览器左上角的右箭头按钮;

from selenium import webdriver
import time

driver = webdriver.Firefox()    # 火狐浏览器
driver.get("https://www.baidu.com/")
time.sleep(5)   # 设置休眠时间(秒)
driver.get("https://www.hao123.com/")
time.sleep(5)   # 设置休眠时间(秒)
driver.back()       # f返回上一页
driver.forward()    # 下一页

五、设置窗口大小
1.可以设置浏览器窗口大小,如设置窗口大小为手机分辨率540*960;
2.也可以最大化窗口;

from selenium import webdriver
import time

driver = webdriver.Firefox()    # 火狐浏览器
driver.get("https://www.baidu.com/")
time.sleep(5)   # 设置休眠时间(秒)
driver.set_window_size(540, 960)    # 设置窗口大小
driver.maximize_window()    # 窗口最大化

六、退出
1.退出有两种方式,一种是close;另外一种是quit;
2.close用于关闭当前窗口,当打开的窗口较多时,就可以用close关闭部分窗口;
3.quit用于结束进程,关闭所有的窗口;
4.最后结束测试,要用quit。quit可以回收c盘的临时文件;

from selenium import webdriver
import time

driver = webdriver.Firefox()    # 火狐浏览器
driver.get("https://www.baidu.com/")
time.sleep(5)   # 设置休眠时间(秒)
driver.close()  # 关闭当前窗口
driver.quit()   # 退出浏览器

原文地址:https://www.cnblogs.com/hoyun/p/10452714.html

时间: 2024-12-10 13:14:42

Selenium2+python自动化-操作浏览器基本方法的相关文章

Selenium2+python自动化61-Chrome浏览器(chromedriver)【转载】

前言 selenium2启动Chrome浏览器是需要安装驱动包的,但是不同的Chrome浏览器版本号,对应的驱动文件版本号又不一样,如果版本号不匹配,是没法启动起来的. 一.Chrome遇到问题 1.如果在启动chrome浏览器时候,出现如下界面,无法打开网址,那么首先恭喜你,踩到了坑,接下来的内容或许对你有所帮助 >># coding:utf-8>>from selenium import webdriver >>driver = webdriver.Chrome()

Selenium2+python自动化61-Chrome浏览器(chromedriver)

前言 selenium2启动Chrome浏览器是需要安装驱动包的,但是不同的Chrome浏览器版本号,对应的驱动文件版本号又不一样,如果版本号不匹配,是没法启动起来的. 一.Chrome遇到问题 1.如果在启动chrome浏览器时候,出现如下界面,无法打开网址,那么首先恭喜你,踩到了坑,接下来的内容或许对你有所帮助 >># coding:utf-8 >>from selenium import webdriver >>driver = webdriver.Chrome(

Selenium2+Python自动化-处理浏览器弹窗(转载)

本篇转自博客:上海-小T 原文地址:http://blog.csdn.net/real_tino/article/details/59068827 我们在浏览网页时经常会碰到各种花样的弹窗,在做UI自动化测试的时候势必要处理这些弹窗,这里就介绍一下目前前端界两种弹窗的处理方法. 一.alert弹窗  这种弹窗是最简单的一种,Selenium里有自带的方法来处理它,用switch_to.alert先定位到弹窗,然后使用一系列方法来操作: accept - 点击[确认]按钮 dismiss - 点击

Selenium2+python自动化45-18种定位方法(find_elements)【转载】

前言 江湖传言,武林中流传八种定位,其中xpath是宝刀屠龙,css是倚天剑. 除了这八种,其实还有十种定位方法,眼看就快失传了,今天小编让失传已久的定位方法重出江湖! 一.十八种定位方法 前八种是大家都熟悉的,经常会用到的 1.id定位:find_element_by_id(self, id_)2.name定位:find_element_by_name(self, name)3.class定位:find_element_by_class_name(self, name)4.tag定位:find

Selenium2+python自动化39-关于面试的题

前言 最近看到群里有小伙伴贴出一组面试题,最近又是跳槽黄金季节,小编忍不住抽出一点时间总结了下, 回答不妥的地方欢迎各位高手拍砖指点. 一.selenium中如何判断元素是否存在? 首先selenium里面是没有这个方法的,判断元素存在需要自己写一个方法了. 元素存在有几种形式,一种是页面有多个元素属性重复的,这种直接操作会报错的:还有一种是页面隐藏的元素操作也会报错 判断方法参考这篇:Selenium2+python自动化36-判断元素存在 二.selenium中hidden或者是displa

Selenium2+python自动化41-绕过验证码(add_cookie)

前言 验证码这种问题是比较头疼的,对于验证码的处理,不要去想破解方法,这个验证码本来就是为了防止别人自动化登录的.如果你能破解,说明你们公司的验证码吗安全级别不高,那就需要提高级别了. 对应验证码,要么是让开发在测试环境弄个万能的验证码,如:1234,要么就是尽量绕过去,如本篇介绍的添加cookie的方法. 一.fiddler抓包 1.前一篇讲到,登录后会生成一个已登录状态的cookie,那么只需要直接把这个值添加到cookies里面就可以了. 2.可以先手动登录一次,然后抓取这个cookie,

Selenium2+python自动化55-unittest之装饰器(@classmethod)【转载】

本篇转自博客:上海-悠悠 原文地址:http://www.cnblogs.com/yoyoketang/tag/unittest/ 前言 前面讲到unittest里面setUp可以在每次执行用例前执行,这样有效的减少了代码量,但是有个弊端,比如打开浏览器操作,每次执行用例时候都会重新打开,这样就会浪费很多时间. 于是就想是不是可以只打开一次浏览器,执行完用例再关闭呢?这就需要用到装饰器(@classmethod)来解决了. 一.装饰器 1.用setUp与setUpClass区别 setup():

Selenium2+python自动化41-绕过验证码(add_cookie)【转载】

前言 验证码这种问题是比较头疼的,对于验证码的处理,不要去想破解方法,这个验证码本来就是为了防止别人自动化登录的.如果你能破解,说明你们公司的验证码吗安全级别不高,那就需要提高级别了. 对于验证码,要么是让开发在测试环境弄个万能的验证码,如:1234,要么就是尽量绕过去,如本篇介绍的添加cookie的方法. 一.fiddler抓包 1.前一篇讲到,登录后会生成一个已登录状态的cookie,那么只需要直接把这个值添加到cookies里面就可以了. 2.可以先手动登录一次,然后抓取这个cookie,

Selenium2+python自动化55-unittest之装饰器(@classmethod)

前言 前面讲到unittest里面setUp可以在每次执行用例前执行,这样有效的减少了代码量,但是有个弊端,比如打开浏览器操作,每次执行用例时候都会重新打开,这样就会浪费很多时间. 于是就想是不是可以只打开一次浏览器,执行完用例再关闭呢?这就需要用到装饰器(@classmethod)来解决了. 一.装饰器 1.用setUp与setUpClass区别 setup():每个测试case运行前运行teardown():每个测试case运行完后执行setUpClass():必须使用@classmetho