文章目录

  • 准备工作
  • 元素定位
  • 操作测试对象
    • 鼠标点击与键盘输入
    • 智能等待、submit提交表单、获得text文本元素
    • 打印title和url
  • 浏览器的操作
  • 键盘事件
  • 鼠标事件

准备工作

  • 最好安装好火狐浏览器或者Chrome浏览器和其对于的driver驱动(注意版本对应, 网上很好下载)
  • 有Python+selenium环境

元素定位

  • 象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。一个对象就是一个人一样,他会有各种的特征(属性),如比我们可以通过一个人的身份证号,姓名,或者他住在哪个街道、楼层、门牌找到这个人。
  • 那么一个对象也有类似的属性,我们可以通过这个属性找到这对象。
  • 注意:不管用那种方式,必须保证页面上该属性的唯一性
  • webdriver 提供了一系列的对象定位方法,常用的有以下几种
    id
    name
    class name
    link text
    partial link text
    tag name
    xpath
    css selector
  • 下面演示通过各种定位去定位一个百度输入框
from selenium import webdriver
import time# 开启驱动
dirver = webdriver.Chrome()
dirver.get("http://www.baidu.com")
# 通过id定位
dirver.find_element_by_id("kw").send_keys("詹姆斯")
# 等待俩秒
time.sleep(2)
# 清空
dirver.find_element_by_id("kw").clear()
# 通过name定位
dirver.find_element_by_name("wd").send_keys("勒布朗")
time.sleep(2)
dirver.find_element_by_name("wd").clear()
# 通过tag name定位 也就是标签名 一般不成功 因为一个页面还有多个这样的标签
# dirver.find_element_by_tag_name("input").send_keys("斯蒂芬")
# 通过class name定位
dirver.find_element_by_class_name("s_ipt").send_keys("库里")
time.sleep(2)
dirver.find_element_by_class_name("s_ipt").clear()
# 通过css定位
dirver.find_element_by_css_selector("#kw").send_keys("凯文")
time.sleep(2)
dirver.find_element_by_css_selector("#kw").clear()
# 通过xpath定位 也就是这个元素在页面的路径
dirver.find_element_by_xpath("//*[@id='kw']").send_keys("杜兰特")
# 点击
dirver.find_element_by_id("su").click()
time.sleep(5)
  • 还有通过link去定位 分为准确定位和模糊定位
from selenium import webdriver
import timedriver = webdriver.Chrome()
driver.get("http://www.baidu.com")
# 通过全名链接定位
# driver.find_element_by_link_text("学术").click()
# 通过模糊链接名定位 如果有多个匹配 则都打开
driver.find_element_by_partial_link_text("图").click()
time.sleep(3)
driver.close()

操作测试对象

  • 般来说,webdriver 中比较常用的操作对象的方法有下面几个:
    click 点击对象
    send_keys 在对象上模拟按键输入
    clear 清除对象的内容,如果可以的话
    submit 清除对象的内容,如果可以的话
    text 用于获取元素的文本信息

鼠标点击与键盘输入

send_keys(“xx”) 用于在一个输入框里输入xx 内容。
click() 用于点击一个按钮。
clear() 用于清除输入框的内容,比如百度输入框里默认有个“请输入关键字”的信息,再比如我们的登陆框一般默认会有“账号”“密码”这样的默认信息。clear 可以帮助我们清除这些信息。

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import timedriver = webdriver.Chrome()
driver.get("http://www.baidu.com")
# send_keys表示输入什么
driver.find_element_by_id("kw").send_keys("詹姆斯")
time.sleep(2)
# click表示鼠标点击一下
driver.find_element_by_id("su").click()
# clear表示清空输入的
driver.find_element_by_id("kw").clear()
time.sleep(2)

智能等待、submit提交表单、获得text文本元素

  • 通过添加implicitly_wait() 方法就可以方便的实现智能等待;implicitly_wait(30)的用法应该比time.sleep() 更智能,后者只能选择一个固定的时间的等待,前者可以在一个时间范围内智能的等待。
# submit表示一个表单的提交
driver.find_element_by_id("kw").send_keys("库里")
# 智能等待 就是只要加载好就执行下面 不像sleep是必须等待时间到
# 设置时间表示最大等待设置的那个时间
driver.implicitly_wait(10)
driver.find_element_by_id("su").submit()
# text表示获取元素文本的内容
text = driver.find_element_by_xpath("//*[@id='con-ar']/div/div/div/table/tbody[1]/tr[1]/td[1]/a").text
print(text)

打印title和url

# 打印title和url
title = driver.title
url = driver.current_url
print(title + " " + url)

浏览器的操作

from selenium import webdriver
import timedriver = webdriver.Firefox()
driver.get("http://www.baidu.com")
# 浏览器操作
# 最大化
driver.maximize_window()
time.sleep(2)
# 最下化
driver.minimize_window()
time.sleep(2)
# 设置高和宽
driver.set_window_size(500, 500)
time.sleep(2)
# 前进和后退
# 再访问百度的基础上再去访问搜狗
driver.get("http://www.sogou.com")
time.sleep(2)
# 后退
driver.back()
time.sleep(2)
# 前进
driver.forward()# 滚动条的控制
# 将滚动条到底部
js = "var q=document.documentElement.scrollTop=10000"
driver.execute_script(js)
time.sleep(2)
# 将滚动条到顶部
js = "var q=document.documentElement.scrollTop=0"
driver.execute_script(js)

键盘事件

  • 要想调用键盘按键操作需要引入keys 包:
    from selenium.webdriver.common.keys import Keys
    通过send_keys()调用按键如:
    send_keys(Keys.TAB) # TAB
    send_keys(Keys.ENTER) # 回车
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import timedriver = webdriver.Chrome()
driver.get("http://www.baidu.com")
# send_keys表示输入什么
driver.find_element_by_id("kw").send_keys("詹姆斯")
time.sleep(2)
# click表示鼠标点击一下
driver.find_element_by_id("su").click()
# clear表示清空输入的
driver.find_element_by_id("kw").clear()
time.sleep(2)
# submit表示一个表单的提交
driver.find_element_by_id("kw").send_keys("库里")
# 智能等待 就是只要加载好就执行下面 不像sleep是必须等待时间到
# 设置时间表示最大等待设置的那个时间
driver.implicitly_wait(10)
driver.find_element_by_id("su").submit()
# text表示获取元素文本的内容
text = driver.find_element_by_xpath("//*[@id='con-ar']/div/div/div/table/tbody[1]/tr[1]/td[1]/a").text
print(text)# 打印title和url
title = driver.title
url = driver.current_url
print(title + " " + url)# 键盘按键的使用
# 使用组合键将输入框删除再输入新的东西 最后使用enter键表示查找
# 使用ctrl + a全选
driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'a')
time.sleep(5)
# 使用退格键删除
driver.find_element_by_id("kw").send_keys(Keys.BACK_SPACE)
time.sleep(2)
# 再次输入东西
driver.find_element_by_id("kw").send_keys("李白")
time.sleep(2)
# 使用enter查找
driver.find_element_by_id("kw").send_keys(Keys.ENTER)

鼠标事件

ActionChains 类
context_click() 右击
double_click() 双击
drag_and_drop() 拖动
move_to_element() 移动

  • 这里也是必须导入下面的包:
    from selenium.webdriver.common.action_chains import ActionChains

ActionChains(driver)
生成用户的行为。所有的行动都存储在actionchains 对象。通过perform()存储的行为。
move_to_element(menu)
移动鼠标到一个元素中,menu 上面已经定义了他所指向的哪一个元素
perform()
执行所有存储的行为

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains
import timedriver = webdriver.Chrome()
driver.get("http://www.baidu.com")
# 鼠标起点
button = driver.find_element_by_link_text("更多")
time.sleep(2)
# 将鼠标移到这里
target = driver.find_element_by_xpath("//*[@id='s-top-more']/div[3]/a")
# 执行移动 移动和这类似使用的是move_to_element
ActionChains(driver).drag_and_drop(button, target).perform()
time.sleep(5)
# 鼠标双击
ActionChains(driver).double_click(target).perform()
time.sleep(3)
# 鼠标右击
kw = driver.find_element_by_id("kw")
ActionChains(driver).context_click(kw).perform()

selenium~初识自动化测试之元素的定位、对象的操作、浏览器的操作、键盘事件、鼠标事件相关推荐

  1. 自动化测试之元素的定位

    目录 一.元素定位 1.根据id属性进行定位(id是唯一的) 2.name属性进行定位 3.tag name(标签名) 定位和class name(标签中的class属性)定位 (1)使用class ...

  2. Web UI自动化测试之元素定位

    目前,在自动化测试的实际应用中,接口自动化测试被广泛使用,但UI自动化测试也并不会被替代.让我们看看二者的对比: 接口自动化测试是跳过前端界面直接对服务端的测试,执行效率和覆盖率更高,维护成本更低,整 ...

  3. UI自动化测试之元素定位方法

    Python语言Selenium库UI自动化测试(一)元素定位方法 简介 当我们日常搭建自动化测试框架时,用Python调用浏览器时,通常有Requests库.Selenium库 这两个库是进行爬虫或 ...

  4. Selenium2学习(八)-- 操作元素(键盘和鼠标事件)

    前言 在前面的几篇中重点介绍了一些元素的到位方法,到位到元素后,接下来就是需要操作元素了.本篇总结了web页面常用的一些操作元素方法,可以统称为行为事件 有些web界面的选项菜单需要鼠标悬停在某个元素 ...

  5. html选择按键点击后锁死输入框_js Dom为页面中的元素绑定键盘或鼠标事件

    html鼠标事件 onload 页面加载 onclick 鼠标单击 onmouSEOver 鼠标移入 onmouSEOut 鼠标移出 onfocus 获取焦点 onblur 失去焦点 onchange ...

  6. 在搜索框自动输入文本_selenium自动化测试之常见的定位元素

    01一.Selenium介绍 Selenium 是什么?一句话,自动化测试工具.它支持各种浏览器,包括 Chrome,Safari,Firefox 等主流界面式浏览器,如果你在这些浏览器里面安装一个 ...

  7. Appium移动端自动化测试之元素定位(三)

    1.name定位 driver.find_element_by_id('com.shanjian.originaldesign:id/edit_Tel').send_keys('15817252876 ...

  8. JS事件对象5--阻止默认事件(鼠标事件)

    阻止默认事件的两种方式和兼容方式: <script type="text/javascript">//阻止系统默认事件的两种方式://1.IE:return false ...

  9. Web UI自动化测试之Selenium工具篇

    本文大纲截图: 一.自动化测试介绍 1.基本介绍 1.1 自动化 概念: 由机器设备代替人工自动完成指定目标的过程 优点: 1)减少人工劳动力 2)提高工作效率 3)产品规格统一标准 4)规模化(批量 ...

最新文章

  1. logging日志配置,day95下午
  2. 16进制与字符串之间的相互转换
  3. 树莓派搭建minecraft服务器
  4. 1.IntelliJ IDEA搭建SpringBoot的小Demo
  5. 菜鸟教程 之 HTML DOM 和 浏览器BOM
  6. linux关闭交互模式,linux – 关闭cp(copy)命令的交互模式(cp:overwrite?)
  7. Pandas快速上手(一):基本操作
  8. ASP.NET 状态视图概览
  9. 中兴被逼入绝境,或将出售手机业务?
  10. 问题:Cannot assign a device for operation Variable
  11. ListView控件详解
  12. 程序员需要掌握哪些软技能?
  13. 利用border设置transparent绘制图形
  14. xshell的快捷复制粘贴设置(*)
  15. c语言乘法除法结合律,C语言运算符的优先级和结合律
  16. 深度学习中优化算法小结
  17. Pr入门系列之二:导入与管理素材
  18. CF1428 G1,G2 . Lucky Numbers题解
  19. mac升级编译器gcc方法
  20. 詹姆斯·西蒙斯 - 金融业的数学大师

热门文章

  1. python淘宝爬虫基于requests抓取淘宝商品数据_python淘宝爬虫基于requests抓取淘宝商品数据...
  2. windows的图片浏览器
  3. 10 款超级实用的Chrome 黑科技插件
  4. 协程的原理及协程在高并发服务中的应用
  5. Alamofire 框架封装与使用
  6. 当 AlphaGo 升级版本 Master 横扫围棋大师,我们来聊聊如何学习AI
  7. C语言实现通讯录【一】(未优化)
  8. 汽车电子学习笔记---LIN
  9. Linux fsck 检测修复文件系统
  10. android 动态壁纸设计