0


selenium之滚动鼠标滑动页面

在浏览web网站时,经常需要进行滑动页面的操作。在selenium中,我们可以通过execute_script执行js语句实现页面滑动。

可以分为四种滑动的场景:滑动至底部、滑动至顶部、滑动至具体位置、滑动至目标元素可见

以百度搜索为例:

一、滑动至顶部

输入搜索内容后,点击百度一下,滑动页面至底部

from selenium import webdriver
import time
from selenium.webdriver.support.wait import WebDriverWait

driver = webdriver.Chrome()
driver.get('http://www.baidu.com')

# 等待元素出现,再执行操作
WebDriverWait(driver, 20).until(lambda driver:driver.find_element('id', 'kw')).send_keys('selenium')
WebDriverWait(driver, 20).until(lambda driver:driver.find_element('id', 'su')).click()

time.sleep(2)
# 模拟鼠标滚轮,滑动至页面底部
js = "window.scrollTo(0, document.body.scrollHeight)"
driver.execute_script(js)

二、滑动至顶部

time.sleep(2)
# 模拟鼠标滑动到顶部
js = "window.scrollTo(0,0)"
driver.execute_script(js)

三、滑动到具体位置

time.sleep(1)
js = "window.scrollTo(0, 500)"   # 向下滑动500个像素
driver.execute_script(js)
time.sleep(1)
js = "window.scrollTo(0, -500)"   # 向上滑动500个像素
driver.execute_script(js)

js = "window.scrollTo(500, 0)"   # 向右滑动500个像素
js = "window.scrollTo(-500, 0)"   # 向左滑动500个像素

四、滑动至目标元素可见

# 目标元素
ele = driver.find_element('xpath', '/html/body/div[1]/div[2]/div[6]/div/div/div[2]/div/div[1]/div/div[2]/div[3]/div[1]/div/a')
# 向下滚动至目标元素可见
js = "arguments[0].scrollIntoView();"
driver.execute_script(js, ele)
# 向上滚动至目标元素可见
js = "arguments[0].scrollIntoView(false);"
driver.execute_script(js, ele)

本文转载自: https://blog.csdn.net/weixin_48323589/article/details/131408956
版权归原作者 喵 所有, 如有侵权,请联系我们删除。

“selenium之滚动鼠标滑动页面”的评论:

还没有评论