网站首页 > 知识剖析 正文
selenium支持几种操作滚动条的方法,主要介绍如下:
使用ActionChains 类模拟鼠标滚轮操作
使用函数ActionChains.send_keys发送按键Keys.PAGE_DOWN往下滑动页面,发送按键Keys.PAGE_UP往上滑动页面。
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
driver = webdriver.Safari()
# 打开一个网页
driver.get("https://www.toutiao.com/")
driver.maximize_window()
sleep(6)
actions = webdriver.ActionChains(driver)
# 向下翻页
actions.send_keys(Keys.PAGE_DOWN).perform()
# 向上翻页
actions.send_keys(Keys.PAGE_UP).perform()
使用函数execute_script执行js脚本滚动页面
可以使用如下三种方式
1)使用window.scrollBy(x, y)
driver.execute_script('window.scrollBy(0, 1000)')
参数解释:
x:正数表示向右滑动的像素值,负数表示向左滑动的像素值
y:正数表示向下滑动的像素值,负数表示向上滑动的像素值
2)使用window.scrollTo(x, y)
driver.execute_script('window.scrollTo(0, 1000)')
参数解释:
x:正数表示向右滑动到某个像素值,负数表示向左滑动到某个像素值
y:正数表示向下滑动到某个像素值,负数表示向上滑动到某个像素值
3)使用
document.documentElement.scrollTop()设置滚动条高度
设置滚动高度为某个像素值:
driver.execute_script("document.documentElement.scrollTop=1000")
测试代码:使用上面3个方式向下滚动,然后再向上滚动(中间通过sleep等待几秒方便观察效果).
from selenium import webdriver
from selenium.webdriver.common.by import By
driver = webdriver.Safari()
# 打开一个网页
#driver.get("http://www.sahitest.com/demo/framesTest.htm")
driver.get("https://www.toutiao.com/")
driver.maximize_window()
sleep(6)
#向下滚动
driver.execute_script('window.scrollBy(0, 100)')
sleep(1)
driver.execute_script('window.scrollTo(0, 200)')
sleep(1)
driver.execute_script("document.documentElement.scrollTop=300")
sleep(1)
#向上滚动
driver.execute_script('window.scrollBy(0, -100)')
sleep(1)
driver.execute_script('window.scrollTo(0, -200)')
sleep(1)
driver.execute_script("document.documentElement.scrollTop=-300")
sleep(1)
使用函数execute_script执行js脚本滚动到特定元素
我们可以直接找到需要滚动到的元素位置,并使用scrollIntoView方法滚到该位置
示例代码:
from selenium import webdriver
from selenium.webdriver.common.by import By
driver = webdriver.Safari()
driver.get("https://www.toutiao.com/")
driver.maximize_window()
sleep(6)
# 找到某个目标元素
element = driver.find_element(By.XPATH,'//*[@id="root"]/div/div[5]/div[2]/div[6]/a[15]')
# 滚动到目标元素
driver.execute_script("arguments[0].scrollIntoView();", element)
共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”
-----指水滴不断地滴,可以滴穿石头;
-----比喻坚持不懈,集细微的力量也能成就难能的功劳。
----感谢读者的阅读和学习,谢谢大家。
猜你喜欢
- 2025-04-07 强大的 Web 应用自动化测试工具 Selenium.WebDriver
- 2025-04-07 delphi TChromium控件(delphi常用控件)
- 2025-04-07 如何使用 Scrapy 执行 JavaScript
- 2025-04-07 以「山河令」为实战案例,手把手教你用Python爬取「优酷」评论
- 2025-04-07 VBA编程,如何对窗体滚动条进行上下左右移动,这个方法真实用
- 2025-04-07 关于web自动化过程中滑块解锁问题以及页面滚动的问题的研究
- 2025-04-07 IOS遇到的几个H5坑、h5键盘弹起遮挡输入框的处理
- 04-29php开发者composer使用看这一篇就够了
- 04-29引用和变量声明在不同语言中的实作
- 04-29PHP 没你想的那么差
- 04-29Ubuntu linux 上的 Nginx 和 Php 安装
- 04-29CentOS下通过yum搭建lnmp(单版本PHP)
- 04-29为什么 PHP8 是个高性能版本
- 04-29PHP8函数包含文件-PHP8知识详解
- 04-29使用无参数函数进行命令执行
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)