web自动化(python)——selenium工具基本使用
WebDriver基本操作
生成driver——启动浏览器
#启动谷歌浏览器,预先安装chromedrvier插件
from selenium import webdriver
driver = webdriver.Chrome()
打开页面
driver.get(url)
窗口操作
大小调整
# 窗口最大化
driver.maxmize_window()
# 窗口最小化
driver.minmize_window()
# 设定宽高,单位px
driver.set_window_size()
前进后退
# 后退
driver.back()
# 前进
driver.forward()
# 刷新
driver.refresh()
关闭和退出
# 关闭
driver.quit()
# 退出
driver.close()
定位方式
分类:
element和element(返回列表)
定位方式
# 利用ID定位
driver.find_element_by_id(cont)
# 利用NAME定位
driver.find_element_by_name(cont)
# 利用CLASS_NAME定位
driver.find_element_by_class_name(cont)
# 利用CSS_SELECTOR定位
driver.find_element_by_css_selector(cont)
# 利用XPATH定位,分为相对路径和绝对路径
driver.find_element_by_xpath(cont)
# 利用LINK_TEXT定位
driver.find_element_by_link_text(cont)
# 利用TAG_NAME定位
driver.find_element_by_tag_name(cont)
优先级
ID> NAME>CSS_SELECTOR>XPATH
基本键盘鼠标操作
- click() # 单击
- send_keys() # 输入
- clear() # 清空
等待方式
强制等待
import time
time.sleep(S)
隐式等待
driver.implicitly_wait(S)
显示等待
# 导入模块
from selenium.webdriver.support.ui import WebDriverWait
# 打来页面时开始查询元素,找到后立即执行
WebDrivewrWait(driver,timeout,intberval).until(lambda driver: driver.find_XXX(XX))
窗口切换
iframe 切换
# 切进
driver.switch_to.frame(ele)
# 切进去,多层时需要一层一层切换,切换回时直接退回默认位置
driver.switch_to.default_content()
alert (弹窗)切换
# 确定
driver.switch_to.alert.accept()
# 取消
driver.switch_to.alert.dismiss()
windows窗口切换
# 获得句柄的列表
driver.window_handles()
# 跳转窗口,回到首页使用index=0
driver.seitch_to.window(window_handles[index])
下拉选择框
# 导入库
from selenium.Webdriver.support.select import Select
sele_le = driver.find_element_by_id(cont)
# 按下标选择
select(sele_le).select_by_index(intnum)
# 根据值选择
select().deselect_by_visible_text(value)
通过验证码
使用万能验证码(开发设置)
使用添加cookie的方式
免于登录,顺便绕过验证码
driver.add_cookie({"name":"XXX","value":"XXX"})
通过查看接口的方式来获取所有登录时获得的cookie;
图像识别技术(OTP引擎)
屏蔽验证码
文件上传
通过send_keys()
driver.find_element_by_id("Idvalue").send_keys(path)
driver.find_element_by_xpath("").click()
通过Pykeyboara,需要依次安装pyHook和PyUserInput
使用sikulik的jar包
其他,比如AutoIt
鼠标键盘操作
鼠标操作
from selenium.webdriver.common.action_chains import Actionchains
# 用Actionchains增强driver
# 点击右键
ActionChains(driver).context_click(ele).perform()
# 双击
ActionChains(driver).double_click(ele).perform()
# 悬停
ActionChains(driver).move_to_element(ele).perform()
# 长按
ActionChains(driver).click_and_hold(ele).perform()
# ActionChains用于生成用户的行为,所有的行为都存储在ActionChains对象,通过perform()执行存储的行为
键盘操作
from selenium.webdriver.common.keys import Keys
# 直接对元素进行按键操作
ele.send_keys("key")
# 组合按键操作
ele.send_keys(keys.xxx,"key1","key2")
截图
方法一:
driver.get_screenshot_as_file(path+"name.png")
方法二:
# 遇到弹窗就截图
driver.save_screenshot(path+"name.png")
方法三:
# 保存的是base64()格式的文件值,html测试报告里插入图片会用到
s=driver.get_screenshot_as_base64()
方法四:
# 保存二进制文件
S = driver.get_screenshot_as_png()
js注入
移动滚动条
方式1(只支持有ID的滚动条):
js = "var q=document.documentElement.scrollTop=100"
js_n = "var q=document.documentElement.scrollTop=0"
driver.execute_script(js_n)
方式2(拖动到指定元素):
target1=dr.find_element_by_xpath("//*[text()='页面']")
driver.execute_script("arguments[0].scriollIntoView();",target1)
修改属性
# 修改某个元素的属性
js = "document.getElementById('idname').name=value"
driver.execute_script(js)
web自动化(python)——selenium工具基本使用的更多相关文章
- WEB自动化(Python+selenium)的API
在做Web自动化过程中,汇总了Python+selenium的API相关方法,给公司里的同事做了第二次培训,分享给大家 ...
- 【python+selenium的web自动化】- Selenium WebDriver原理及安装
简单介绍 selenium selenium是一个用于测试web网页的自动化测试工具,它直接运行在浏览器中,模拟用户的操作.
- 技术分享 | Web自动化之Selenium安装
Web 应用程序的验收测试常常涉及一些手工任务,例如打开一个浏览器,并执行一个测试用例中所描述的操作.但是手工执行的任务容易出现人为的错误,也比较费时间.因此,将这些任务自动化,就可以消除人为因素.S ...
- web自动化之selenium
一.Selenium(http://www.selenium.org/) Web自动化测试工具.它支持各种浏览器,包括Chrome,Safari,Firefox等主流界面式浏览器,如果你在这些浏览器里 ...
- web自动化之selenium(二)
selenium自动化测试框架 一.什么是自动化测试 利用软件(或者说机器代替人)实现全部或者部分测试任务的过程 二.为什么要进行自动化测试 自动化测试可以完成许多手工测试无法实现或难以实现的功能 ...
- web自动化之selenium(一)
自动化搭建环境 1.自动搭建(一) #安装 pip install webdriver-helper 1.1示例 from webdriver_helper import * #get_webdriv ...
- web自动化之selenium(六)利用坐标点定位
这是通过第三发库实现对元素的定位,因为在无法定位元素的时候,只能通过外部来定位,此时就可以使用pyautogui模块,操作鼠标,模拟人进行操作 # 使用注意事项,不要过于的依赖它 1.使用时需要在通过 ...
- web自动化测试python+selenium学习总结----selenium安装、浏览器驱动下载
一.安装selenium 命令安装selenium库 :pip install -U selenium 查看selenium是否安装成功:pip list PS:有时会有异常,安装失败,可以尝试去s ...
- web自动化:selenium原理和元素定位(一)
一. Selenium2 WebDriver 当Selenium2.x提出了WebDriver的概念后,它提供了完全另外的一种方式与浏览器交互 那就是利用浏览器原生的API,封装成一套更加面向对象的S ...
- web自动化,selenium环境配置
1,首先我们需要在python编译器中添加selenium插件,我用的是pycharm 点击下方的Terminal,然后在命令行输入: pip install selenium 也可以在设置里面手动添 ...
随机推荐
- Hive学习目录
大数据之Hive学习目录 第 1 章 Hive入门 1.1 什么是Hive 1.2 Hive的优缺点 1.2.1 优点 1.2.2 缺点 1.3 *Hive架构原理 1.4 Hive和数据库比较 第 ...
- 第4章 SparkSQL数据源
第4章 SparkSQL数据源 4.1 通用加载/保存方法 4.1.1 手动指定选项 Spark SQL的DataFrame接口支持多种数据源的操作.一个DataFrame可以进行RDDs方式的操作, ...
- Golang omitempty 的用法
原文链接:https://blog.csdn.net/skh2015java/article/details/90720692omitempty作用是在json数据结构转换时,当该字段的值为该字段类型 ...
- 使用分区挂载 ftp 目录
ftp挂载分区上去后无法识别的问题困扰了我好几天,今天有时间把它研究了一下,拿出来与大家分享一下. ftp目录挂载分区前与挂载分区后的区别[root@localhost ~]# ls -Zd /var ...
- 2020.5.26 第六篇 Scrum冲刺博客
Team:银河超级无敌舰队 Project:招新通 项目冲刺集合贴:链接 目录 一.每日站立会议 1.1 会议照片 1.2 项目完成情况 二.项目燃尽图 三.签入记录 3.1 代码/文档签入记录 3. ...
- 《Head First 设计模式》:外观模式
正文 一.定义 外观模式提供了一个统一的接口,用来访问子系统中的一群接口.外观定义了一个高层接口,让子系统更容易使用. 要点: 外观模式将一个或数个类的复杂的一切都隐藏在背后,只显露出一个干净美好的外 ...
- Java中抽象类和接口的介绍及二者间的区别
接口(Interface)和抽象类(Abstract Class)是支持抽象类定义的两种机制. 一.抽象类 在Java中被abstract关键字修饰的类称为抽象类,被abstract关键字修饰的方法称 ...
- 区块链入门到实战(17)之以太坊(Ethereum) – 是什么
以太坊的作用:构建基于区块链的分布式应用. 以太坊是什么:可编程的虚拟币. 以太坊(Ethereum)是一个可编程的虚拟币,它是一个基于公共区块链的分布式计算平台,可用于构建基于区块链的分布式应用. ...
- poi解析Excel内容
poi可以将指定目录下的Excel中的内容解析.读取到java程序中.下面是一个Demo: 使用poi需要导下包,如下: 首先是准备读取的Excel表,存放在"E:\programming\ ...
- Java面试题(多线程篇)
多线程 35.并行和并发有什么区别? 1.并行是指两个或者多个事件在同一时刻发生:而并发是指两个或多个事件在同一时间间隔发生. 2.并行是在不同实体上的多个事件,并发是在同一实体上的多个事件. 3.在 ...