WebDriver API剖析----元素、鼠标、键盘的操作

一、元素的操作

1、清除元素的内容

clear()方法用于清除元素中已有的内容。

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")

driver.find_element(By.ID, "kw").send_keys("selenium")
sleep(2)
driver.find_element(By.ID, "kw").clear()  

sleep(3)
driver.quit()

2、提交表单

submit()方法用于提交form表单内容或是模拟回车操作,有时可替代click()方法。

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")

driver.find_element(By.ID, "kw").send_keys("selenium")
sleep(2)
# driver.find_element(By.ID, "kw").clear()  
driver.find_element(By.ID, "kw").submit() 
sleep(3)
driver.quit()

3、获取元素的大小

size方法用于获取元素尺寸。下面代码获取百度首页的【百度一下】按钮的大小:

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")
button = driver.find_element(By.ID, "su").size
print(button)
driver.quit()

运行代码,可以在pycharm控制台得到结果{'height': 44.0, 'width': 108.0}。 

 二、鼠标操作

在自动化测试工程中,可能会遇到页面中的某个元素,需要把鼠标光标移动到该元素上面蔡能显示出来。当遇到这情况时,可借助ActionChains类来处理。

需要先导入类ActionChains类,代码如下:

from selenium.webdriver.common.action_chains import ActionChains

所有的行为都存储在ActionChains对象中,再通过perform()方法执行所有ActionChains对象中存储的行为。perform()也是ActionChains类提供的方法,通常与ActionChains()配合使用。ActionChains方法的说明可参考如下。

ActionChains方法列表
方法        说明
click(on_element=None)单击鼠标左键
context_click(on_element=None)单击鼠标右键
double_click(on_element=None)双击鼠标左键
drag_and_drop(source, target)拖曳到某个元素上然后松开
drag_and_drop_by_offset(source, xoffset, yoffset)拖曳到某个坐标上然后松开
key_down(value, element=None)按下键盘上的某个键
key_up(value, element=None)松开某个键
move_by_offset(xoffset, yoffset)光标从当前位置移动到某个坐标上
move_by_element(to_element)光标移动到某个元素上
move_to_element_with_offset(to_element,xoffset,yoffset)移动到距某个元素(左上角坐标)多少距离的位置
perform()执行所有ActionChains中存储的行为
release(on_element=None)在某个元素位置松开鼠标左键
send_keys(*keys_to_send)

发送某个键到当前焦点的元素

1、右击操作

context_click()方法时先定位一个元素,然后对定位的元素执行右击。首先我们要先定位一个元素,其次执行需要的操作,最后需要提交操作。

以百度首页为例,在【百度一下】按钮进行右击操作,代码如下:

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")
sleep(2)
right = driver.find_element(By.ID, "su")
ActionChains(driver).context_click(right).perform()
sleep(2)
driver.quit()

2、双击操作

double_click()方法用于对元素进行操作。以百度首页上的【百度一下】按钮为例,对其进行发起双击操作。代码如下:

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")
sleep(2)
double = driver.find_element(By.ID, "su")
ActionChains(driver).double_click(double).perform()
sleep(2)
driver.quit()

3、拖动操作

 drag_and_drop()方法实现原色拖动的功能,即通过鼠标拖曳某个元素到指定的原色后再松开。写了一段HTML代码举例,代码如下:

<html>
	<head>

	<style type="text/css">
		#div1{
			width:300px;
			height:100px;
			padding:10px;
			border:1px solid #aaaaaa
		}
	</style>
	<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
	<script src="http://apps.bdimg.com/libs/jqueryui/1.10.4/jquery-ui.min.js"></script>
	<script type="text/javascript">
		$(function(){
			$("#drag1").draggable();
			$('#div1').droppabel({
			drop:function(event, ui){
				alert("图片放置成功");
			}
			});
		});
	</script>
	</head>
	<body>
	 <p>请把图片拖放到方框中:</p>
	 <div id="div1"></div>
	 <br/>
	 <img id="drag1" src="https://cdn.ptpress.cn/pubcloud/3/app/0718A6B0/cover/20191204BD54009A.png">
	</body>
</html>	

 这边介绍两种方式来实现该功能。python实现代码如下:

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains

driver = webdriver.Firefox()
driver.get("file:///F:/TestDragDrop.html")
# 第一种方式
# element = driver.find_element(By.ID, "drag1")
# target = driver.find_element(By.ID, "div1")
# ActionChains(driver).drag_and_drop(element, target).perform()
# sleep(3)


# 第二种方式
ActionChains(driver)\
    .click_and_hold(driver.find_element(By.ID, "drag1"))\
    .move_to_element(driver.find_element(By.ID, "div1"))\
    .release()\
    .perform()
driver.quit()

:虽然ActionChains提供了丰富的鼠标操作功能,且可以直接拖放元素,但是目前selenium只至耻以JavaScript方式实现拖曳功能(本例子拖放功能就是通过JavaScript实现的),对于直接用HTML5方式实现的拖放功能,selenium尚不支持。但可以通过selenium来执行JavaScript代码以模拟这种操作。

三、键盘操作

selenium提供了比较完整的键盘操作,同样的,在模拟键盘操作之前需要导入Keys类,代码如下:

from selenium.webdriver.common.keys import Keys

Keys类几乎提供了 所有按键的方法,如下表:

常用的键盘操作
引用方法对应键盘
send_keys(Keys.BACK_SPACE)删除键(BackSpace)
send_keys(Keys.SPACE)空格键(Space)
send_keys(Keys.ESCAPE)回退键(Esc)
send_keys(Keys.TAB)制表键(Tab)
send_keys(Keys.ALTERNATE)换挡键(Alt)
send_keys(Keys.ENTER)回车键(Enter)
send_keys(Keys.SHIFT)大小写转换键(Shift)
send_keys(Keys.CONTROL, 'a')全选(ctrl+A)
send_keys(Keys.CONTROL, 'c')复制(ctrl+c)
send_keys(Keys.CONTROL, 'x')剪切(ctrl+x)
send_keys(Keys.CONTROL, 'v')粘贴(CTRL+v)
send_keys(Keys.F1)F1键
send_keys(Keys.F12)F12键
send_keys(Keys.PAGE_UP)向上翻页键(page up)
send_keys(Keys.PAGE_DOWN)向下翻页键(page down)
send_keys(Keys.LEFT)向左方向键(Left)
send_keys(Keys.RIGHT)向右方向键(Right)

常见的键盘操作代码实现如下:

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from time import sleep
from selenium.webdriver.common.by import By

driver = webdriver.Firefox()
driver.get("https://www.baidu.com")
driver.find_element(By.ID, "kw").send_keys("selenium")
sleep(2)
# 输入删除键
driver.find_element_by_id('kw').send_keys(Keys.BACK_SPACE)
sleep(2)
# 在搜索框输入bella
driver.find_element_by_id('kw').send_keys('bella')
sleep(2)
# 输入CTRL+A(全选操作)
driver.find_element_by_id('kw').send_keys(Keys.CONTROL, 'a')
sleep(2)
# 输入CTRL+x(剪切操作)
driver.find_element_by_id('kw').send_keys(Keys.CONTROL, 'x')
sleep(2)
# 输入ctrl+v(粘贴操作)
driver.find_element_by_id('kw').send_keys(Keys.CONTROL, 'v')
sleep(2)
# 输入回车键
driver.find_element_by_id('kw').send_keys(Keys.ENTER)

driver.quit()

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值