基于python3.6,selenium3.141,详细资料介绍查看官方API文档,点击这里

一、对浏览器操作

 driver = webdriver.Chrome()  # 初始化chrome
driver1 = webdriver.Firefox() # 初始化Firefox
driver2 = webdriver.Ie() # 初始化IE
driver3 = webdriver.Edge() # # 初始化Edge
driver.get("https://www.baidu.com") # 打开url
driver.capabilities['version'] # 获取浏览器version
driver.maximize_window() # 将浏览器最大化显示
driver.set_window_size(480, 800) # 设置浏览器宽480、高800显示
driver.back() # 浏览器后退
driver.forward() # 浏览器前进
driver.title # 获取当前页面的title
driver.current_url # 获取当前页面的URL
driver.current_window_handle # 获取当前浏览器窗口的句柄
driver.close() # 关闭浏览器,关闭当前浏览器,即最上层那个
driver.quit() # 关闭webdriver打开的所有浏览器
各浏览器驱动下载地址,注意版本要对上
Chrome:http://npm.taobao.org/mirrors/chromedriver/
Edge:https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/
Firefox:https://github.com/mozilla/geckodriver/releases
Safari:https://webkit.org/blog/6900/webdriver-support-in-safari-10/
IE:http://selenium-release.storage.googleapis.com/index.html

二、页面元素定位

最好使用id,name的方式定位元素,因为一般这两个元素是全局唯一的;有时候元素不唯一,推荐使用xpath或者css定位,根据个人喜好而定,不推荐使用class

 # return :WebElement - the element if it was found
driver.find_element(By.ID, 'foo')
driver.find_element_by_id("foo")
driver.find_element_by_name("foo")
driver.find_element_by_class_name("foo")
driver.find_element_by_tag_name("h1")
driver.find_element_by_link_text("Sign In")
driver.find_element_by_partial_link_text("Sign")
driver.find_element_by_xpath("//div/td[1]")
driver.find_element_by_css_selector("#foo")
 # return: list of WebElement - a list with elements if any was found. An empty list if not
driver.find_elements(By.CLASS_NAME, 'foo')
driver.find_elements_by_id("foo")
driver.find_elements_by_name("foo")
driver.find_elements_by_class_name("foo")
driver.find_elements_by_tag_name("h1")
driver.find_elements_by_link_text("Sign In")
driver.find_elements_by_partial_link_text("Sign")
driver.find_elements_by_xpath("//div[contains(@class, 'foo')]")
driver.find_elements_by_css_selector("#foo")

三、页面元素操作

 # 清除输入框的默认内容
driver.find_element_by_id("foo").clear()
# 输入框里输入context
driver.find_element_by_id("foo").send_keys("context")
# 单击一个按钮
driver.find_element_by_id("foo").click()
# 提交表单
driver.find_element_by_id("foo").submit()
# 返回元素的尺寸
driver.driver.find_element_by_id("foo").size
# 获取元素文本
driver.find_element_by_id("foo").text
# 返回元素的属性值,元素拥有的任意属性。如果是input的,可以通过获取value值获得当前输入的值
driver.find_element_by_id("foo").get_attribute('value')
# 返回元素的结果是否可见,返回结果为True或False
driver.find_element_by_id("foo").is_displayed()

四、鼠标事件

 from selenium.webdriver.common.action_chains import ActionChains
# 定位鼠标元素
mouse = driver.find_element_by_id("foo")
# 对定位到的元素执行鼠标右键操作
ActionChains(driver).context_click(mouse).perform()
# 对定位到的元素执行鼠标双击操作
ActionChains(driver).double_click(mouse).perform()
# 对定位到的元素执行鼠标移动到上面的操作
ActionChains(driver).move_to_element(mouse).perform()
# 对定位到的元素执行鼠标左键按下的操作,注意这里是点击下去不释放
ActionChains(driver).click_and_hold(mouse).perform() # 鼠标拖放操作
element = driver.find_element_by_id("foo1") # 定位元素的原位置
target = driver.find_element_by_id("foo2") # 定位元素要移动到的目标位置
ActionChains(driver).drag_and_drop(element, target).perform() # 执行元素的移动操作

五、键盘事件

 from selenium.webdriver.common.keys import Keys

 driver.find_element_by_id("foo").send_keys(Keys.BACK_SPACE)  # 删除键(BackSpace)
driver.find_element_by_id("foo").send_keys(Keys.SPACE) # 空格键(Space)
driver.find_element_by_id("foo").send_keys(Keys.TAB) # 制表键(Tab)
driver.find_element_by_id("foo").send_keys(Keys.ESCAPE) # 回退键(Esc)
driver.find_element_by_id("foo").send_keys(Keys.ENTER) # 回车键(Enter)
driver.find_element_by_id("foo").send_keys(Keys.DELETE) # 删除键(Delete)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'a') # 全选(Ctrl+A)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'c') # 复制(Ctrl+C)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'x') # 剪切(Ctrl+X)
driver.find_element_by_id("foo").send_keys(Keys.CONTROL, 'v') # 粘贴(Ctrl+V)

python+selenium自动测试之WebDriver的常用API(基础篇一)的更多相关文章

  1. python+selenium自动测试之WebDriver的常用API(基础篇二)

    本篇介绍一下python+selenium复杂操作的处理,基于python3.6,selenium3.141,详细资料介绍查看官方API文档,点击这里 一.常见特殊情况处理如iframe/弹窗处理 有 ...

  2. Python + Selenium 自动发布文章(一):开源中国

    https://blog.csdn.net/qq_28804275/article/details/80891949 https://blog.csdn.net/qq_28804275/article ...

  3. Python+selenium常用方法(Webdriver API)

    小编整理了目前学习的Python+selenium常用的一些方法函数,以后有新增再随时更新. 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() ...

  4. python selenium自动化测试之路(1)--分层测试概念、selenium工具介绍

    1.分层自动化测试概念 传统的自动化市场更关注产品UI层的自动化测试,而分层的自动化测试倡导产品开发的不同阶段都需要自动化测试 大多公司与研发团队其实是忽略了单元测试与集成测试阶段的自动化测试工作,所 ...

  5. Python+selenium自动化测试之浏览器基础操作

    **​​前言** 本文主要讲解webdriber框架,Selenium 就像真实用户所做的一样,Selenium 测试可以在 Windows.Linux 和 Macintosh上的 Internet ...

  6. ASP.NET Web API 基础篇1

    ASP.NET Web API 直到我膝盖中了一箭[1]基础篇 无题 蓦然回首,那些年,我竟然一直很二. 小时候,读武侠小说的时候,看到那些猪脚,常常会产生一种代入感,幻想自己也会遭遇某种奇遇,遇到悬 ...

  7. 我拖拖拖--H5拖放API基础篇

    不要搞错,本文不是讲如何拖地的.看过<javascript精粹>朋友应该知道,他实现拖放的过程比较复杂,现在时代不同了,我们用H5的新的拖放API就能非常方便的实现拖放效果了.最近在园子见 ...

  8. [selenium webdriver Java]常用api

    1. 获取元素文本 WebElement类的getText()方法返回元素的innerText属性.所以元素里如果有子节点一样也会被返回出来.如下所示 public class GetText { @ ...

  9. Python+selenium自动循环扔QQ邮箱漂流瓶

    Python代码如下: # coding=utf-8 from selenium import webdriver from time import sleep from random import ...

随机推荐

  1. CF_528D

    一句话题意 给你两个串s.t,长度为n.m,字符集为"ATGC",当且仅 当[i - k; i + k]中存在一个j,使得s[j ] = t[x]时,s[i ]可以 和t[x]匹配 ...

  2. CF997C Sky Full of Stars

    CF997C Sky Full of Stars 计数好题 在Ta的博客查看 容斥式子:发现只要每个钦定方案的贡献都考虑到再配上容斥系数就是对的 O(n^2)->O(n) 把麻烦的i=0,j=0 ...

  3. Nginx与前端开发

    Nginx与Node.js "Nginx是一款轻量级的HTTP服务器,采用事件驱动的异步非阻塞处理方式框架,这让其具有极好的IO性能,时常用于服务端的反向代理和负载均衡." 作为前 ...

  4. (八)控件介绍,QLable

    Radio单选框 默认互斥,加GroupBox进行分组可以解决这个 checkBox复选 ListWidget TableWIdget:有表头 #include "widget.h" ...

  5. TODO springboot学习笔记

    学习中,是在是搞不懂是什么狗屎....

  6. django上传图片简单验证以及自动修改图片名称

    django实现文件(图片)上传之后自动修改名称以及页面上传图片时的各种提醒: 1.先在你项目中添加一个文件夹如:system 在文件夹下添加__init__.py 和storage.py文件,并在s ...

  7. 【强大的PDF格式转换工具】Lighten PDF Converter OCR for Mac 6.2.0

    [简介] Lighten PDF Converter OCR 是一款Mac上强大的PDF格式转换工具,可以将PDF文档快速批量的转换为Office (Word, Excel, PowerPoint), ...

  8. windows一键部署java项目

    windows一键部署java项目 因为公司需求,要在windows的环境上做一键部署启动java项目,同时还要支持从安装界面动态修改配置文件的IP地址.就像安装软件一样将jdk,tomcat,mys ...

  9. Java反射-修改字段值, 反射修改static final修饰的字段

    反射修改字段 咱们从最简单的例子到难, 一步一步深入. 使用反射修改一个private修饰符的变量name 咱们回到主题, 先用反射来实现一个最基础的功能吧. 其中待获取的name如下: public ...

  10. Ubuntu屏幕分辨率无1920 1080

    xrandr 没有1920X1080分辨率,所以手动添加一个1080P分辨率,先输入“cvt 1920 1080”命令,查询一下1080P分辨率的有效扫描频率 然后 sudo xrandr --new ...