ホームページ  >  記事  >  バックエンド開発  >  Python Selenium のマウスとキーボード操作で遊んでみる (ActionChains)

Python Selenium のマウスとキーボード操作で遊んでみる (ActionChains)

高洛峰
高洛峰オリジナル
2017-02-22 17:19:452894ブラウズ

Selenium をオートメーションに使用する場合、クリック、ダブルクリック、右クリック、ドラッグなどのマウス操作をシミュレートする必要がある状況に遭遇することがあります。 Selenium は、このようなイベントを処理するクラス - ActionChains

selenium.webdriver.common.action_chains.ActionChains(driver)

を提供します。このクラスは基本的にマウス操作のすべてのニーズを満たすことができます。

1. ActionChains の基本的な使い方

まず、ActionChains のメソッドを呼び出すと、すべての操作が順番にキューに保存されます。 . Perform() メソッドを呼び出すと、キュー内の時間が順番に実行されます。

この場合、2 つの呼び出しメソッドを使用できます:

•チェーン書き込み

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()

•ステップバイステップ書き込み

れーい

2 つの記述方法は基本的に同じであり、ActionChains はすべての操作を順番に実行します。

2.ActionChainsメソッド一覧

click(on_element=None) ——マウスの左ボタンをクリック

click_and_hold(on_element=None) ——マウスの左ボタンを放さずにクリック

context_click(on_element=None ) ——マウスの右ボタンをクリック

double_click(on_element=None) ——マウスの左ボタンを 2 回クリック

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_to_element(to_element) —— マウスを要素に移動

move_to_element_with_offset(to_element, xoffset, yoffset) —— 要素 (左上) までの距離 (角度座標) に移動

Perform() —— チェーン内のすべてのアクションを実行します

release(on_element=None) —— 要素の位置でマウスの左ボタンを放します

send_keys(*keys_to_send) —— Send 現在フォーカスされている要素にキーを送信します

send_keys_to_element(element, *keys_to_send) - 指定された要素にキーを送信します

次に、例を使用して、各メソッドの使用法を詳しく説明し、示します:

3. コード例

1. クリック操作

URL の例 http://www.php.cn/;

コード:

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()

結果:

[CLICK][DOUBLE_CLICK][RIGHT_CLICK]

2. マウスの移動

サンプル URL http ://www.php.cn/;

サンプルコード:

# -*- coding: utf-8 -*-

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


driver = webdriver.Firefox()
driver.implicitly_wait(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"]') # 右键单击按钮


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(2)
driver.quit()

結果

マウスを移動

マウスを移動

3. ドラッグ

URLの例 http://www.php.cn /;

コード:

# -*- coding: utf-8 -*-

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

driver = webdriver.Firefox()
driver.implicitly_wait(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')

# action.move_to_element(blank).perform()
action.move_by_offset(10, 50).perform() # 移动到距离当前位置(10,50)的点,与上句效果相同,移动到blank上,清空
print result.get_attribute('value')

action.move_to_element_with_offset(blank, 10, -40).perform() # 移动到距离blank元素(10,-40)的点,可移动到write上
print result.get_attribute('value')

sleep(2)
driver.quit()

結果:

ドロップドロップドロップドロップドロップ

一般的に、座標位置決めはほとんど使用されず、上記の例の方法 1 で十分です まあ、ソースコードを見るとを見ると、メソッド 2 が実際にはメソッド 1 の drag_and_drop() の実装であることがわかります。注: ドラッグ アンド ドロップを使用する場合は、速度が速すぎて失敗する場合があるため、待ち時間に注意してください。

4. ボタン

ボタンをシミュレートするには、win32api、SendKeys、または Selenium の WebElement オブジェクトの send_keys() メソッドを使用して実装できるさまざまな方法があります。

URL の例 http://www.php.cn/;

コード 1:

# -*- coding: utf-8 -*-

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

driver = webdriver.Firefox()
driver.implicitly_wait(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('//p[text()="Item 1"]') # 目标元素1
item2 = driver.find_element_by_xpath('//p[text()="Item 2"]') # 目标2
item3 = driver.find_element_by_xpath('//p[text()="Item 3"]') # 目标3
item4 = driver.find_element_by_xpath('//p[text()="Item 4"]') # 目标4

action = ActionChains(driver)
action.drag_and_drop(dragger, item1).perform() # 1.移动dragger到目标1
sleep(2)
action.click_and_hold(dragger).release(item2).perform() # 2.效果与上句相同,也能起到移动效果
sleep(2)
action.click_and_hold(dragger).move_to_element(item3).release().perform() # 3.效果与上两句相同,也能起到移动的效果
sleep(2)
# action.drag_and_drop_by_offset(dragger, 400, 150).perform() # 4.移动到指定坐标
action.click_and_hold(dragger).move_by_offset(400, 150).release().perform() # 5.与上一句相同,移动到指定坐标
sleep(2)
driver.quit()

結果:

キーを押した charCode=[0] keyCode=[17] CTRL
キーを押した charCode =[0] keyCode=[16] なし
キーが押されました charCode=[97] keyCode=[0] なし

例 2:

サンプル URL http://www.php.cn/;

コード:

# -*- coding: utf-8 -*-

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

driver = webdriver.Firefox()
driver.implicitly_wait(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()

結果:

Test Keys
Test Keys

コピーと貼り付けは、WebElementd5fd7aea971a85678ba271703566ebfd.send_keys() を使用して行うこともできます。また、低レベルのメソッドを使用することもできます。問題に対処する方法の 1 つは win32api です。興味がある場合は、SendKeys と keybd_event も試してみてください

以上がこの記事の全内容です。また、皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。

Python Selenium のマウスとキーボード操作 (ActionChains) で遊ぶことに関するその他の関連記事については、PHP 中国語 Web サイトに注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。