文件上传:

对于通过input标签实现的上传功能,可以将其看作是一个输入框,即通过send_keys()指定本地文件路径的方式实现文件上传

创建upfile.html文件,代码如下:

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>upload_file</title>
<link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css" rel="stylesheet" />
</head>
<body><div class="row-fluid"><div class="span6 well"><h3>upload_file</h3><input type="file" name="file" /></div></div>
</body>
<script src="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.js"></scrip>
</html>

  

通过浏览器打开upfile.html文件,功能如下图

接下来通过send_keys()方法来实现文件上传

from selenium import webdriver
import osdriver = webdriver.Firefox()
file_path = 'file:///' + os.path.abspath('upfile.html')
driver.get(file_path)# 定位上传按钮,添加本地文件
driver.find_element_by_name("file").send_keys('D:\\upload_file.txt')driver.quit()

 

cookie操作

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

WebDriver操作cookie的方法:

  • get_cookies(): 获得所有cookie信息

  • get_cookie(name): 返回字典的key为“name”的cookie信息

  • add_cookie(cookie_dict) : 添加cookie。“cookie_dict”指字典对象,必须有name 和value 值

  • delete_cookie(name,optionsString):删除cookie信息 “name”是要删除的cookie的名称,“optionsString”是该cookie的选项,目前支持的选项包括“路径”,“域”

  • delete_all_cookies(): 删除所有cookie信息

下面通过get_cookies()来获取当前浏览器的cookie信息

from selenium import webdriverdriver = webdriver.Firefox()
driver.get("http://www.youdao.com")# 获得cookie信息
cookie= driver.get_cookies()
# 将获得cookie的信息打印
print(cookie)driver.quit()

 

从执行结果可以看出,cookie数据是以字典的形式进行存放的 知道了cookie的存放形式,接下来我们就可以按照这种形式向浏览器中写入cookie信息

from selenium import webdriverdriver = webdriver.Firefox()
driver.get("http://www.youdao.com")# 向cookie的name 和value中添加会话信息
driver.add_cookie({'name': 'key-aaaaaaa', 'value': 'value-bbbbbb'})# 遍历cookies中的name 和value信息并打印,当然还有上面添加的信息
for cookie in driver.get_cookies():print("%s -> %s" % (cookie['name'], cookie['value']))driver.quit()

 输出结果:

YOUDAO_MOBILE_ACCESS_TYPE -> 1
_PREF_ANONYUSER__MYTH -> aGFzbG9nZ2VkPXRydWU=
OUTFOX_SEARCH_USER_ID -> -1046383847@218.17.158.115
JSESSIONID -> abc7qSE_SBGsVgnVLBvcu
key-aaaaaaa -> value-bbbbbb

从执行结果可以看到,最后一条cookie信息是在脚本执行过程中通过add_cookie()方法添加的 通过遍历得到所有的cookie信息,从而找到key为“name”和“value”的特定cookie的value

调用JavaScript代码

虽然WebDriver提供了操作浏览器的前进和后退方法,但对于浏览器滚动条并没有提供相应的操作方法 在这种情况下,就可以借助JavaScript来控制浏览器的滚动条 WebDriver提供了execute_script()方法来执行JavaScript代码

用于调整浏览器滚动条位置的JavaScript代码如下:

<!-- window.scrollTo(左边距,上边距); -->
window.scrollTo(0,450);

window.scrollTo()方法用于设置浏览器窗口滚动条的水平和垂直位置 方法的第一个参数表示水平的左间距,第二个参数表示垂直的上边距 其代码如下:

from selenium import webdriver
from time import sleep# 访问百度
driver=webdriver.Firefox()
driver.get("http://www.baidu.com")# 设置浏览器窗口大小
driver.set_window_size(500, 500)# 搜索
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
sleep(2)# 通过javascript设置浏览器窗口的滚动条位置
js="window.scrollTo(100,450);"
driver.execute_script(js)
sleep(3)driver.quit()

通过浏览器打开百度进行搜索,并且提前通过set_window_size()方法将浏览器窗口设置为固定宽高显示,目的是让窗口出现水平和垂直滚动条。然后通过execute_script()方法执行JavaScripts代码来移动滚动条的位置

窗口截图:

自动化用例是由程序去执行的,因此有时候打印的错误信息并不十分明确 如果在脚本执行出错的时候能对当前窗口截图保存,那么通过图片就可以非常直观地看出出错的原因 WebDriver提供了截图函数get_screenshot_as_file()来截取当前窗口

from selenium import webdriver
from time import sleepdriver = webdriver.Firefox()
driver.get('http://www.baidu.com')driver.find_element_by_id('kw').send_keys('selenium')
driver.find_element_by_id('su').click()
sleep(2)# 截取当前窗口,并指定截图图片的保存位置
driver.get_screenshot_as_file("D:\\baidu_img.jpg")driver.quit()

脚本运行完成后打开D盘,就可以找到baidu_img.jpg图片文件了

最后关闭浏览器:

在前面的例子中我们一直使用quit()方法,其含义为退出相关的驱动程序和关闭所有窗口 除此之外,WebDriver还提供了close()方法,用来关闭当前窗口 例多窗口的处理,在用例执行的过程中打开了多个窗口,我们想要关闭其中的某个窗口,这时就要用到close()方法进行关闭了

  • close() 关闭单个窗口

  • quit() 关闭所有窗口

注:目前处于自学python阶段,上述所写属于学习笔记 如有错误,欢迎指正 !  喜欢的朋友可以加我QQ 1441121610! 

 

转载于:https://www.cnblogs.com/haozong/p/11303381.html

selenium (二)相关推荐

  1. python自动测试p-python网络爬虫之自动化测试工具selenium[二]

    @ 前言 hello,大家好,在上章的内容里我们已经可以爬取到了整个网页下来,当然也仅仅就是一个网页. 因为里面还有很多很多的标签啊之类我们所不需要的东西. 额,先暂且说下本章内容,如果是没有丝毫编程 ...

  2. java selenium (二) 环境搭建方法一

    webdriver 就是selenium 2.    webdriver 是一款优秀的,开源的,自动化测试框架. 支持很多语言.  本文描述的是用java Eclipse 如何搭建环境 阅读目录 首先 ...

  3. selenium 二维码登陆解决方案

    selenium与api 的结合 获取到 qr_id 然后api 带这个qr_id 调用,然后就ok了 实现方式看代码 # -*- coding: utf-8 -*- # auth: cy # cre ...

  4. Selenium(二)_控件定位及简单操作

    以百度页面为例: 定位控件的方法 1.通过id来定位(唯一 ,不能定位到多个) driver.find_element_by_id('kw').send_keys('药家鑫') driver.find ...

  5. java操作selenium(二)-微博自动登录后回复

    简单介绍下逻辑 步骤: 1.登录 先判断是否有cookie,有cookie直接登录,cookie失效使用账号密码登录,开始尝试登录,登录时会判断是否需要验证码(我用的是云打码平台,百度一下就知道了,这 ...

  6. selenium网页自动登录、打卡(二)

    文章目录 前言 一.Python+Selenium 二.通信环境(服务器.客户端) 1. selenium借助cookie网页登录csdn 2.私信发送消息流程 3.将新增的逻辑融入原本的程序 前言 ...

  7. Python 安装selenium

    一.报错信息 No module named 'selenium' 二.系统环境 操作系统:Win10 64位 Python版本:Python 3.7.0 三.安装参考 1.使用pip安装seleni ...

  8. Selenium + Nightwatch 自动化测试环境搭建

    首先要安装 Java 7 或更高 ,(http://www.oracle.com/technetwork/java/javase/downloads/index.html) 并且 java 命令可正常 ...

  9. 爬虫学习笔记(二十一)—— Appium

    文章目录 一.概念和作用 1.1.概念 1.2.常见应用 1.3.特点 1.4.Appium和Selenium 二.安装 2.1.安装Appium客户端库 2.2.安装Appium Desktop 2 ...

最新文章

  1. POJ - 2387 Til the Cows Come Home
  2. 目标检测入门和实现思路!
  3. docker快速入门教程
  4. 软件测试-PR录制脚本程序ie的时候闪退
  5. 脑芯编:窥脑究竟,织网造芯(二)
  6. CF1479A Searching Local Minimum
  7. MediaCodec的使用和若干问题处理
  8. 梯度下降法、牛顿法和拟牛顿法——机器学习面试
  9. excel 粘贴到web_使用EXCEL导入参考历年高考大数据,为2019年高考志愿填报做参考...
  10. 南方cass简码识别大全_CASS分类简码
  11. 怎么将计算机的网络恢复连接,怎么修复互联网连接 修复网络连接方法【介绍】...
  12. android获取webview url,android - webview获取到当前页面的url
  13. win10 外接usb摄像头_win10系统外接摄像头不能用怎么办
  14. 维基链WICC | 项目进展周报第57期(1.6~1.12)
  15. JSP中访问本地图片
  16. easyexcel导入时读不到数据_EasyExcel快速读写Excel数据
  17. 全球及中国连续性肾脏替代治疗机行业发展趋势及前景规划分析报告2022-2027
  18. GZIP压缩和解压缩不删除原始文件
  19. 抓包工具 Charles使用教程---抓取接口数据
  20. python的字符串一些方法

热门文章

  1. win7记事本txt图标显示异常解决方法
  2. Linux NFS存储服务部署
  3. FPGA--(verilog)一个完整工程的设计(包含设计块和激励块)及仿真
  4. C#窗口的Load事件与Shown事件的差别
  5. Eclipse启动Tomcat时45秒超时的解决方法
  6. 一次面试留下的实际应用问题。关于HttpModule,IIS集成模式。
  7. 虚拟机VMware Workstation与主机间共享文件(利用虚拟光驱)
  8. JS:ES6-7 迭代器与生成器
  9. JavaScript实现限制文件上传类型和大小
  10. 计算机网络—体系结构相关真题练习(二)