总结Selenium自动化测试方法(四)WebDriver常用的操作

摘要:
注意:在使用隐式等待的时

四、WebDriver常用的操作

1、控制浏览器操作

#控制浏览器的大小

self.driver.set_window_size(480,800)

#控制浏览器返回

self.driver.back()

#控制浏览器前进到下个页面

self.driver.forward()

#刷新当前页面

self.driver.refresh()

2、控制页面元素的简单操作

#清除文本操作

self.driver.find_element_by_xpath("/div/div[2]/div/div/div").clear()

#模拟键盘输入值

self.driver.find_element_by_xpath("/div/div[2]/div/div/div").send_keys(“urstest@163.com”)

#点击元素

self.driver.find_element_by_xpath("/div/div[2]/div/div/div").click()

#提交表单

self.driver.find_element_by_xpath("/div/div[2]/div/div/div").submit()

#返回输入框尺寸

size=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").size

print(size)

#返回文本内容

text=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").text

print(text)

#返回元素的属性值

attribute1=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").get_attribute(‘id’)

print(attribute1)

attribute2=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").get_attribute(‘name’)

print(attribute2)

attribute3=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").get_attribute(‘type’)

print(attribute3)

#返回元素的结果是否可见,返回结果是True或是False

result=self.driver.find_element_by_xpath("/div/div[2]/div/div/div").is_displayed()

print(result)

#返回页面标题

title=self.driver.title

print(title)

#返回页面url

url=self.driver.current_url

print(url)

#上传文件,上传文件相当于给元素传值,可以用send_keys()函数

self.driver.find_element_by_xpath("/div/div[2]/div/div/div").send_keys(‘D:\upload_file.txt’)

3、鼠标操作

首先要导入鼠标操作的Actionchains类

#引入Actionchains类

from selenium import webdriver

from selenium.webdriver.common.action_chains import ActionChains

然后就可以用下面的这些函数进行鼠标的操作了

#左键用上面讲到的click()函数就可以了

#右键

right_click= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

ActionChains(driver).context_click(right_click).perform()

#双击

double_click= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

ActionChains(driver).double_click(double_click).perform()

#拖拽

#拖拽的原位置

element= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

#拖拽的目标位置

target= self.driver.find_element_by_xpath("/div/div[2]/div/div/div[2]")

#执行拖拽

ActionChains(driver).drag_and_drop(element,target).perform()

4、键盘操作

首先要导入键盘操作的Keys类

#引入Keys类

from selenium import webdriver

from selenium.webdriver.common.keys import Keys

然后就可以用下面的这些函数进行键盘的操作了

#输入内容:用之前的send_keys()函数即可

#回删内容

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text.send_keys(Keys.BACK_SPACE)

#输入空格及内容

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text2=text.send_keys(Keys.SPACE)

text2.send_keys(u“就是啊”)

#全选内容ctrl+a

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text.send_keys(Keys.CONTROL,’a’)

#剪切内容ctrl+x

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text.send_keys(Keys.CONTROL,’x’)

#粘贴内容ctrl+v

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text.send_keys(Keys.CONTROL,’v’)

#回车

text= self.driver.find_element_by_xpath("/div/div[2]/div/div/div")

text.send_keys(Keys.ENTER)

5、元素等待操作

①显示等待

原理:显式等待,就是明确的要等到某个元素的出现或者是某个元素的可点击等条件,等不到,就一直等,除非在规定的时间之内都没找到,那么就跳出Exception.(简而言之:就是直到元素出现才去操作,如果超时则报异常)

②隐式等待

原理:隐式等待,就是在创建driver时,为浏览器对象设置一个等待时间。这个方法是得不到某个元素就等待一段时间,直到拿到某个元素位置。

注意:在使用隐式等待的时候,实际上浏览器会在你自己设定的时间内不断的刷新页面去寻找我们需要的元素

③休眠方法sleep

需要导入sleep类

#引入sleep类

from selenium import webdriver

from time import sleep

time.sleep(3)

6、处理验证码(验证码是阻碍自动化测试的部分,所以要想办法绕开这个环节)

①注释掉验证码部分的代码

②设置一个万能验证码

③验证码的识别技术

④记录cookie,来跳过登录的部分

免责声明:文章转载自《总结Selenium自动化测试方法(四)WebDriver常用的操作》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Python使用RedisGit的安装和配置 -入门下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Appium如何自动判断浏览器驱动

问题:有的测试机chrome是这个版本,有的是另一个版本,怎么能让自动判断去跑呢?? 解决办法:使用appium的chromedriverExecutableDir和chromedriverChromeMappingFile 切忌使用chromedriverExecutableDir和chromedriverChromeMappingFile时,一定不要再...

4 使用Selenium模拟登录csdn,取出cookie信息,再用requests.session访问个人中心(保持登录状态)

代码: # -*- coding: utf-8 -*- """ Created on Fri Jul 13 16:13:52 2018 @author: a """ from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdr...

Python自带xml模块实现xpath查询带xmlns命名空间的xml

需求 手上有个项目需要解析xml数据,参考写爬虫的经验,容易想到使用XPath语句进行节点导航。 XPath 是一门在 XML 文档中查找信息的语言,用于在 XML 文档中通过元素和属性进行导航。 XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。 查阅 网上搜了一下,大多推荐...

Appium在ios下获取页面元素的一种新思路

传统思路 手机app页面(框内是要获取的元素): 新的方法: 因为appium在ios中,通过driver.page_source属性,能得到一个xml格式的全部元素。于是采用这种方法,得到了全部元素,适合查询浏览等这类较少操作的页面。 代码如下: 主要用到的方法如下: 导入xml解析模块 1、import xml.etree.ElementTr...

element Image组件

<template> <div class="el-image"> <slot v-if="loading"name="placeholder"> <div class="el-image__placeholder"></div> </slot>...

(包含项目)selenium操作对象的text方法和智能等待时间

基础知识 1  js:JavaScript缩写     json:JavaScript的一种数据格式 2  浏览器的原理:把 html+css+js 下载到本地然后再进行渲染。即看到网页这个过程,实际上是浏览器把代码下载下来,然后浏览器来解释这个代码,变成界面的过程。 3  查看网页源代码:就是别人服务器发送到浏览器的原封不动的代码。这个代码没有被浏览器...