一、窗口截图

dirver.get_screenshot_as_file("D:\\report\\image\\xxx.jpg")

二、关闭窗口

dirver.close()  #关闭当前窗口

driver.quit()  #退出浏览器

三、操作Cookie

有时候我们需要验证浏览器中是否存在某个 cookie,因为基于真实的 cookie 的测试是无法通过白盒和 集成测试完成的。WebDriver 提供了操作 Cookie 的相关方法可以读取、添加和删除 cookie 信息。
webdriver 操作 cookie 的方法有:

 get_cookies()       获得所有 cookie 信息

 get_cookie(name)     返回有特定 name 值有 cookie 信息

 add_cookie(cookie_dict) 添加 cookie,必须有 name 和 value 值

 delete_cookie(name)   删除特定(部分)的 cookie 信息

 delete_all_cookies()   删除所有 cookie 信息 下面通过 get_cookies()来获取当前浏览器的 cookie 信息。

 from selenium import webdriver 

 driver = webdriver.Chrome() driver.get("http://www.youdao.com")

 # 获得cookie信息
cookie= driver.get_cookies()
#将获得cookie的信息打印
print cookie
driver.quit()

四、验证码处理

1. 让开发去掉验证码

2. 让开发设置万能验证码

3. 验证码识别技术(光学字符识别)

4. 记录cookie

 #访问xx网站
driver.get("http://www.xx.cn") #将用户名密码写入浏览器cookie
                  #username        1@1.com
driver.add_cookie({'name':'Login_UserNumber', 'value':'username'})
                  #password        111111
driver.add_cookie({'name':'Login_Passwd', 'value':'password'}) #再次访问xx网站,将会自动登录 driver.get("http://www.xx.cn/")
time.sleep(3)
....
driver.quit()

五、调用JavaScript

调用js一般处理有:控制滚动条,富文本,把隐藏的元素显示出来

1. 控制滚动条

js = "window.scrollTo(100,450);"
browser.execute_script(js)

2. 用js写入富文本

js = "document.getElementById('content_ifr').contentWindow.document.body.innerHTML=''你好,我是富文本!"
browser.execute_script(js)

3. 把隐藏的元素显示出来

六、处理HTML5视频

。。。。

七、上传文件

1. send_keys实现上传

(1)普通上传:普通的附件上传都是将本地文件的路径作为一个值放 input 标签中,通过 form 表单提交的时候将这个值提交给服务器。即可以将其看作是一个输入框,通过send_keys()指定本地文件路径的方式实现上传。

 #打开上传功能页面
file_path = 'file:///' + os.path.abspath('upfile.html') driver.get(file_path) #定位上传按钮,添加本地文件 driver.find_element_by_name("file").send_keys('D:\\upload_file.txt')

(2)插件上传:一般是指基于 Flash 与 JavaScript 或 Ajax 等技术所实现的上传功能或插件。

2. Autolt实现上传

它是一个类似BASIC脚本语言的免费软件,被设计用来进行Windows GUI(图形用户界面)的自动化测试。利用模拟键盘按键,鼠标移动和窗口/控件的组合来实现自动化任务。

AutoItWindows Info 用于帮助我们识 Windows 控件信息。

CompileScript to.exe 用于将 AutoIt 生成 exe 执行文件。
RunScript     用于执行 AutoIt 脚本。
SciTE Script Editor 用于编写 AutoIt 脚本。

1 #点击打开上传窗口
2 driver.find_element_by_name("file").click()
3
4 #调用upfile.exe上传程序
5 os.system("D:\\upfile.exe")
6 driver.quit()

八、下载文件

Webdriver允许我们设置默认的文件下载路径。

只针对Firefox,所以也可以参考使用Autoit工具(上看)

 1 #coding=utf-8
2 from selenium import webdriver
3 import os
4
5 fp = webdriver.FirefoxProfile()
6 # browser.download.folderList设置成 0 代表下载到浏览器默认下载路径;设置成 2 则可以保存到指定目录
7 fp.set_preference("browser.download.folderList",2)
8
9 #browser.download.manager.showWhenStarting
10 是否显示开始,Ture 为显示,Flase 为不显示
11 fp.set_preference("browser.download.manager.showWhenStarting",False)
12
13 #browser.download.dir,用于指定你所下载文件的目录。os.getcwd() 该函数不需要传递参数,用于返回当前的目录。
14 fp.set_preference("browser.download.dir", os.getcwd())
15
16 # browser.helperApps.neverAsk.saveToDisk
17 指定要下载页面的 Content-type 值,“application/octet-stream”为文件的类型。HTTP Content-type 常 用对照表:http://tool.oschina.net/commons
18
19 fp.set_preference("browser.helperApps.neverAsk.saveToDisk", "application/octet-stream")
20
21 #下载文件的类型
22 driver = webdriver.Firefox(firefox_profile=fp)
  driver.get("http://pypi.Python.org/pypi/selenium")
  driver.find_element_by_partial_link_text("selenium-2").click()

Webdriver API之操作(二)的更多相关文章

  1. Webdriver API之操作(一)

    一. 控制浏览器 1. 控制浏览器大小 driver.set_window_size(480,800) #浏览器宽480,高800显示 dirver.maximize_window() #浏览器最大化 ...

  2. WebDriver API——延时操作及元素等待

    在自动化测试过程当中,受网络.测试设备等诸多因素的影响,我们经常需要在自动化测试脚本中添加一些延时来更好的定位元素来进行一系列的操作. 一般有这么几种方式: 1.implicitlyWait.识别对象 ...

  3. Webdriver API (二)

    (转载) 1.3 打开测试页面 对页面对测试,首先要打开被测试页面的地址(如:http://www.google.com),web driver 提供的get方法可以打开一个页面: // And no ...

  4. selenium初识(二)——之webdriver API

    配置完的环境之后,我们先来写一个小脚本: # __Author__:"Jim_xie" from selenium import webdriver from time impor ...

  5. WebDriver API——javascript的相关操作

    有些时候webdriver是没法操作元素或浏览器的,这时候我们可以通过javascript来进行相关的操作,昨天在群里一个朋友定位一个显示框,总是无法定位点击,或者是点击无效,这个时候就可以用java ...

  6. Selenium2+Python:Webdriver API速记手册

    由于web自动化常常需要控制浏览器行为和操作页面元素,相关函数又比较多,于是再此记下一份Webdriver API查阅文档以备不时之需. 参考:虫师<Selenium2自动化测试实战>,和 ...

  7. python+selenium自动化软件测试(第2章):WebDriver API

    2.1 操作元素基本方法 前言前面已经把环境搭建好了,从这篇开始,正式学习selenium的webdriver框架.我们平常说的 selenium自动化,其实它并不是类似于QTP之类的有GUI界面的可 ...

  8. Selenium WebDriver Api 知识梳理

    之前一直没有系统的梳理WebDriver Api的相关知识,今天借此机会整理一下. 1.页面元素定位 1.1.8种常用定位方法 # id定位 driver.find_element_by_id() # ...

  9. InfluxDB学习之InfluxDB的HTTP API查询操作

    在 InfluxDB学习 的上一篇文章:InfluxDB学习之InfluxDB的HTTP API写入操作 中,我们介绍了使用InfluxDB的HTTP API进行数据写入操作的过程,本文我们再来介绍下 ...

随机推荐

  1. Token在android中的使用

    首先Token是一个怎么样的东西,Token存在的意义又在哪里?学过php或是其他web开发的人都知道一个东西叫session和cookie,这些东西可以在服务器或是本地保存一些东西,比如说登录状态, ...

  2. 一位资深程序员给予Java初学者的学习路线建议

    一位资深程序员给予Java初学者的学习路线建议 java学习这一部分其实也算是今天的重点,这一部分用来回答很多群里的朋友所问过的问题,那就是我你是如何学习Java的,能不能给点建议?今天我是打算来点干 ...

  3. Git commit message和工作流规范

    目的 统一团队Git commit日志标准,便于后续代码review,版本发布以及日志自动化生成等等. 统一团队的Git工作流,包括分支使用.tag规范.issue等 Git commit日志参考案例 ...

  4. 基于nodejs模拟浏览器post请求爬取json数据

    今天想爬取某网站的后台传来的数据,中间遇到了很多阻碍,花了2个小时才请求到数据,所以我在此总结了一些经验. 首先,放上我所爬取的请求地址http://api.chuchujie.com/api/?v= ...

  5. 在.NET项目中使用PostSharp,使用CacheManager实现多种缓存框架的处理

    在前面几篇随笔中,介绍了PostSharp的使用,以及整合MemoryCache,<在.NET项目中使用PostSharp,实现AOP面向切面编程处理>.<在.NET项目中使用Pos ...

  6. 1112: [POI2008]砖块Klo

    1112: [POI2008]砖块Klo Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1245  Solved: 426[Submit][Statu ...

  7. 通讯录--(iOS9独有的方法)

    导入库文件   #import <ContactsUI/ContactsUI.h> #pragma mark iOS9 新出的点击通讯录的获取信息的办法 #pragma mark - 先弹 ...

  8. IOS本地日志记录方案

    我们在项目中日志记录这块也算是比较重要的,有时候用户程序出什么问题,光靠服务器的日志还不能准确的找到问题. 现在一般记录日志有几种方式: 1.使用第三方工具来记录日志,如腾讯的Bugly,它是只把程序 ...

  9. linux 私房菜 CH5 笔记

    知识点 linux 大小写敏感 接口的切换 [Ctrl] + [Alt] + [F1] ~ [F6] :文字接口登入 tty1 ~ tty6 终端机: [Ctrl] + [Alt] + [F7] :图 ...

  10. React-Native 之 项目实战(二)

    前言 本文有配套视频,可以酌情观看. 文中内容因各人理解不同,可能会有所偏差,欢迎朋友们联系我. 文中所有内容仅供学习交流之用,不可用于商业用途,如因此引起的相关法律法规责任,与我无关. 如文中内容对 ...