1、https://www.cnblogs.com/lozz/p/13713462.html ElementNotInteractableException,Element could not be scrolled into view
在使用webdriver处理表格的时候,点击tr标签。可能会遇到ElementNotInteractableException,Element could not be scrolled into view错误
参考解决方法:
1、 元素点击前,加等待
try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); }
2. 使用action的方式点击元素
@Override public void clickElementByAction(WebElement element) { Actions actions = new Actions(driver); actions.moveToElement(element).click().perform(); }
===========================================================
2、https://blog.csdn.net/pengjunlee/article/details/90716038 玩转python selenium鼠标键盘操作(ActionChains)
目录
1.ActionChains基本用法
链式写法
分步写法
2.ActionChains方法列表
3.代码示例
1.点击操作
2.鼠标移动
3.拖拽
4.按键
示例1:
示例2:
用selenium做自动化,有时候会遇到需要模拟鼠标操作才能进行的情况,比如单击、双击、点击鼠标右键、拖拽等等。而selenium给我们提供了一个类来处理这类事件——ActionChains
selenium.webdriver.common.action_chains.ActionChains(driver)
这个类基本能够满足我们所有对鼠标操作的需求。
首先需要了解ActionChains的执行原理,当你调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个队列里,当你调用perform()方法时,队列中的时间会依次执行。
这种情况下我们可以有两种调用方法:
menu = driver.find_element_by_css_selector(".nav")
hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")
ActionChains(driver).move_to_element(menu).click(hidden_submenu).perform()
menu = driver.find_element_by_css_selector(".nav")
hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")
actions = ActionChains(driver)
actions.move_to_element(menu)
actions.click(hidden_submenu)
actions.perform()
两种写法本质是一样的,ActionChains都会按照顺序执行所有的操作。
接下来用示例来详细说明和演示每一个方法的用法。
示例网址:http://sahitest.com/demo/clicks.htm
示例代码:
# -*- coding: utf-8 -*-
from time import sleep
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.implicitly_wait(10) # 隐式等待 10 秒钟
driver.maximize_window() # 窗口最大化
driver.get('http://sahitest.com/demo/clicks.htm')
click_btn = driver.find_element_by_xpath('//input[@value="click me"]') # 单击按钮
doubleclick_btn = driver.find_element_by_xpath('//input[@value="dbl click me"]') # 双击按钮
rightclick_btn = driver.find_element_by_xpath('//input[@value="right click me"]') # 右键单击按钮
'''分步写法'''
sleep(2)
ActionChains(driver).click(click_btn).perform() # 在
sleep(2)
ActionChains(driver).double_click(doubleclick_btn).perform() # 在
sleep(2)
ActionChains(driver).context_click(rightclick_btn).perform() # 在
'''链式写法'''
# ActionChains(driver).click(click_btn).double_click(doubleclick_btn).context_click(rightclick_btn).perform()
print(driver.find_element_by_name('t2').get_attribute('value'))
sleep(5)
driver.quit()
结果:
[CLICK][DOUBLE_CLICK][RIGHT_CLICK]
示例网址:http://sahitest.com/demo/mouseover.htm
示例代码:
# -*- coding: utf-8 -*-
from time import sleep
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.implicitly_wait(10) # 隐式等待 10 秒钟
driver.maximize_window() # 窗口最大化
driver.get('http://sahitest.com/demo/mouseover.htm')
write = driver.find_element_by_xpath('//input[@value="Write on hover"]') # 鼠标移动到此元素,在下面的input框中会显示“Mouse moved”
blank = driver.find_element_by_xpath('//input[@value="Blank on hover"]') # 鼠标移动到此元素,会清空下面input框中的内容
result = driver.find_element_by_name('t1')
action = ActionChains(driver)
action.move_to_element(write).perform() # 移动到write,显示“Mouse moved”
print(result.get_attribute('value'))
sleep(2)
# action.move_to_element(blank).perform()
action.move_by_offset(10, 50).perform() # 移动到距离当前位置(10,50)的点,与上句效果相同,移动到blank上,清空
print(result.get_attribute('value'))
sleep(2)
action.move_to_element_with_offset(blank, 10, -40).perform() # 移动到距离blank元素(10,-40)的点,可移动到write上
print(result.get_attribute('value'))
sleep(5)
driver.quit()
结果:
Mouse moved
Mouse moved
示例网址:http://sahitest.com/demo/dragDropMooTools.htm
示例代码:
# -*- coding: utf-8 -*-
from time import sleep
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.implicitly_wait(10) # 隐式等待 10 秒钟
driver.maximize_window() # 窗口最大化
driver.get('http://sahitest.com/demo/dragDropMooTools.htm')
dragger = driver.find_element_by_id('dragger') # 被拖拽元素
item1 = driver.find_element_by_xpath('//div[text()="Item 1"]') # 目标元素1
item2 = driver.find_element_by_xpath('//div[text()="Item 2"]') # 目标2
item3 = driver.find_element_by_xpath('//div[text()="Item 3"]') # 目标3
item4 = driver.find_element_by_xpath('//div[text()="Item 4"]') # 目标4
action = ActionChains(driver)
'''1.将
sleep(1)
action.click_and_hold(dragger).perform() # 在
sleep(1)
action.move_by_offset(2, 20).perform() # 鼠标相对于当前位置移动一定距离
sleep(1)
action.move_by_offset(2, 20).perform() # 鼠标相对于当前位置移动一定距离
sleep(1)
action.move_to_element(item1).perform() # 鼠标移动到
sleep(1)
action.release(dragger).perform() # 释放鼠标左键
# action.drag_and_drop(dragger, item1).perform() # 与上面5步操作结果相同
'''2.将
sleep(2)
action.click_and_hold(dragger).release(item2).perform()
'''3.将
sleep(2)
action.click_and_hold(dragger).move_to_element(item3).release().perform()
'''4.将
sleep(2)
# action.drag_and_drop_by_offset(dragger, 400, 150).perform()
action.click_and_hold(dragger).move_by_offset(400, 150).release().perform()
sleep(5)
driver.quit()
一般用坐标定位很少,而使用 drag_and_drop() 来实现。但需要注意,某些情况下拖拽使用时注意加等待时间,否则,会因为速度太快而失败。
模拟按键有多种方法,能用win32api来实现,能用SendKeys来实现,也可以用selenium的WebElement对象的send_keys()方法来实现,这里ActionChains类也提供了几个模拟按键的方法。
示例网址:http://sahitest.com/demo/keypress.htm
# -*- coding: utf-8 -*-
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.implicitly_wait(10) # 隐式等待 10 秒钟
driver.maximize_window() # 窗口最大化
driver.get('http://sahitest.com/demo/keypress.htm')
key_up_radio = driver.find_element_by_id('r1') # 监测按键升起
key_down_radio = driver.find_element_by_id('r2') # 监测按键按下
key_press_radio = driver.find_element_by_id('r3') # 监测按键按下升起
enter = driver.find_elements_by_xpath('//form[@name="f1"]/input')[1] # 输入框
result = driver.find_elements_by_xpath('//form[@name="f1"]/input')[0] # 监测结果
# 监测key_down
key_down_radio.click()
ActionChains(driver).key_down(Keys.CONTROL, enter).key_up(Keys.CONTROL).perform()
print(result.get_attribute('value'))
# 监测key_up
key_up_radio.click()
enter.click()
ActionChains(driver).key_down(Keys.SHIFT).key_up(Keys.SHIFT).perform()
print(result.get_attribute('value'))
# 监测key_press
key_press_radio.click()
enter.click()
ActionChains(driver).send_keys('a').perform()
print(result.get_attribute('value'))
driver.quit()
结果:
key downed charCode=[0] keyCode=[17] CTRL
key upped charCode=[0] keyCode=[16] NONE
key pressed charCode=[97] keyCode=[97] NONE
示例网址:http://sahitest.com/demo/label.htm
示例代码:
# -*- coding: utf-8 -*-
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.implicitly_wait(10) # 隐式等待 10 秒钟
driver.maximize_window() # 窗口最大化
driver.get('http://sahitest.com/demo/label.htm')
input1 = driver.find_elements_by_tag_name('input')[3]
input2 = driver.find_elements_by_tag_name('input')[4]
action = ActionChains(driver)
input1.click()
action.send_keys('Test Keys').perform()
action.key_down(Keys.CONTROL).send_keys('a').key_up(Keys.CONTROL).perform() # ctrl+a
action.key_down(Keys.CONTROL).send_keys('c').key_up(Keys.CONTROL).perform() # ctrl+c
action.key_down(Keys.CONTROL, input2).send_keys('v').key_up(Keys.CONTROL).perform() # ctrl+v
print(input1.get_attribute('value'))
print(input2.get_attribute('value'))
driver.quit()
结果:
Test Keys
Test Keys
复制粘贴用WebElement< input >.send_keys()也能实现,大家可以试一下,也可以用更底层的方法,同时也是os弹框的处理办法之一的win32api,有兴趣也可以试试SendKeys、keybd_event 。