Python+selenium 自動化高級應用篇:藉助pyautogui實現web前端帶軌跡拖拽功能,解決ActionChains拖拽失效問題

有一些 web 前端的交互,必須有鼠標軌跡才能成功的實現拖拽功能。
selenium 自帶的 ActionChains 方法,是一瞬間從 A 點到 B 點的。
解決思路:

利用元素返回的相對瀏覽器的位置的方法, location[] 可以返回元素的座標,再加上邊框的位移量,確定好元素相對於電腦的位置,這個時候用瀏覽器最大化方法很有必要 driver.maximize_window(),可以固定瀏覽器相對於電腦位置的偏移量,這個偏移量需要大家自己來找,再利用 pyautogui 模擬鼠標操作完美的解決問題,鼠標操作實現電腦座標點到點的軌跡拖動,後面的 duration 可以設置拖動時長。

# 2019.10.10
# 小藍棗
# 實現帶軌跡拖拽功能

# -*- coding: UTF8 -*-
from selenium import webdriver

import os
import time
import pyautogui

driver = webdriver.Chrome()  # 打開谷歌瀏覽器
driver.maximize_window()     # 最大化瀏覽器
driver.implicitly_wait(10) # 設置隱式時間等待

# 拖拽應用
def drag_app(s):
	# 定位起始元素
    start = driver.find_element_by_xpath('//*[@fieldid="left_area"]//*[@fieldid="搜索結果_group"]//*[@fieldid="'+s+'"]//*[@class="list-item-content"]')
    # 讓鼠標移動到起點元素上
    pyautogui.moveTo(start.location['x']+20,start.location['y']+125)
    # 定位要拖拽到的位置元素
    end = driver.find_element_by_xpath('//*[@fieldid="right_area"]//*[@fieldid="分組_group"]//*[@fieldid="container_area"]')
    # 實現拖拽功能
    pyautogui.dragTo(end.location['x']+20,end.location['y']+155,duration=1)
    time.sleep(2)

效果如演示:
在這裏插入圖片描述
喜歡的點個贊❤吧!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章