【Python】selenium实现滚动条滑动效果

2024-09-05 15:36

本文主要是介绍【Python】selenium实现滚动条滑动效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

封装自动化方法:selenuimtools.py

from selenium.common import TimeoutException, InvalidArgumentException, JavascriptException
from selenium.webdriver.common.by import By
from selenium.webdriver.remote.webelement import WebElement
from selenium.webdriver.support.wait import WebDriverWait
import tools.log as Log
from tools.log import MyException
from time import sleep
# selenuim 自动化方法脚本
# 封装组件相关操作
class ElementOperate:def __init__(self, driver, find_timeout: float = 5, sleep_time: float = 1.5):self.driver = driver# 等待组件最长时间self.find_timeout = find_timeout# 操作之间的间隔时间self.sleepT = sleep_time# 获取组件def find_element(self, find_type, element: str) -> WebElement:el = Noneby = Nonedriver = self.driver# 类型转换if find_type == "id":by = By.IDif find_type == "xpath":by = By.XPATHelif find_type == "link":by = By.LINK_TEXTelif find_type == "partial_link":by = By.PARTIAL_LINK_TEXTelif find_type == "name":by = By.NAMEelif find_type == "tag":by = By.TAG_NAMEelif find_type == "class":by = By.CLASS_NAMEelif find_type == "css":by = By.CSS_SELECTORtry:if by is None:# 如果用户未按要求输入,则停止查询raise MyException(f"查找类型错误,类型【{find_type}】不符合要求!!!")# 显式等待组件出现,el = WebDriverWait(driver=driver, timeout=self.find_timeout).until(lambda dv: dv.find_element(by, element), f"查找组件【{element}】超时,组件未在指定时间内出现")except TimeoutException as e:Log.error(e.msg)except MyException as e:Log.error(e)finally:return el# 点击组件def click(self, by: str, element: str) -> bool:el_button = self.find_element(by, element)# 判断是否找到组件if el_button:el_button.click()return Truereturn False# 输入框输入def send_keys(self, by: str, element: str, context: str) -> bool:el_input = self.find_element(by, element)# 判断是否找到组件if el_input:# 先清除输入框内容el_input.clear()el_input.send_keys(context)return Truereturn False# 页面滚动# scroll_y: 滑动高度百分比,不选则滑动置底# times: 完成滑动所需时间,不选则立即完成滑动# sleep_time: 多少秒后开始执行# is_await:是否等待滑动结束def scrollTo(self, scroll_y: float = None,times: int = 0,sleep_time: float = None,is_await: bool = True) -> bool:# 等待页面加载完成,如果页面未加载完就执行,会导致scrollHeight属性错误,变成上一页面的高度而不是当前页面的高度sleep(self.sleepT if sleep_time is None else sleep_time)# 时间为负数时设置为0times = 0 if times < 0 else (times * 1000)# 滚动条高度if scroll_y is None:# 获取页面内容高度scroll_y = self.execute_script("return document.body.scrollHeight")# 滚动条滑动脚本js_code = '''const ScrollTop = (number = 0, time) => {if (!time) {document.body.scrollTop = document.documentElement.scrollTop = number;return number;}const spacingTime = 20; let spacingInex = time / spacingTime;let nowTop = document.body.scrollTop + document.documentElement.scrollTop;let everTop = (number - nowTop) / spacingInex; let scrollTimer = setInterval(() => {if (spacingInex > 0) {spacingInex--;ScrollTop(nowTop += everTop);} else {clearInterval(scrollTimer); }}, spacingTime);};'''js_code = js_code + f"ScrollTop({scroll_y}, {times});"self.execute_script(js_code=js_code)position = 0# 判断滚动条是否已停止滚动while is_await:# 每隔0.1s检测一次sleep(0.1)# 获取当前位置new_position = self.execute_script('return document.body.scrollTop + document.documentElement.scrollTop;')if new_position == position:is_await = Falseposition = new_positionreturn Trueasync def async_scrollTo(self):pass# js 脚本执行,默认同步def execute_script(self, js_code: str, is_async: bool = False):if js_code is None or js_code == "":raise MyException("js脚本为空")try:if not is_async:# 同步执行:适合执行时间较短的js。webdriver 会等待执行结果,然后继续执行后续代码return self.driver.execute_script(js_code)else:# 异步执行:通常执行时间比较长的js。webdriver 不需要等待执行结果,直接执行后续代码return self.driver.execute_async_script(js_code)except (InvalidArgumentException, JavascriptException):Log.error(f"js脚本异常,无法被执行,当前执行脚本内容如下:\n {js_code}")except MyException as e:Log.error(e)

自定义工具类:tools.py

# 输出文本修饰
def error(msgs):print(f"\033[31m****异常报错:{msgs}\033[0m")def info(msgs):print(f"\033[32m****信息输出:{msgs}\033[0m")def warn(msgs):print(f"\033[33m****警告信息:{msgs}\033[0m")# 自定义异常类 MyException,配合log使用
class MyException(Exception):  # 继承异常类def __init__(self, msg):  # 重写父类的__init__方法self.msg = msg

测试代码

from selenium import webdriver
from tools.selenuimtools import ElementOperateclass AutoWebTest:def __init__(self):# 设置浏览器不自动关闭options = webdriver.ChromeOptions()options.add_experimental_option('detach', True)self.driver = webdriver.Chrome(options=options)# 设置浏览器全屏self.driver.maximize_window()# 打开网站def open_web(self, request):self.driver.get(request)driver = ElementOperate(self.driver)driver.send_keys('id', "kw", "selenium")driver.click('id', 'su')driver.scrollTo(times=10,is_await=False)# 当设置is_await为FALSE时,会看到浏览器还在滑动滚动条,但程序已向下执行# 而为TRUE或者不设置时,会看到程序等待浏览器滑动滚动条完毕后,才会向下执行print("已执行")if __name__ == "__main__":str = "https://www.baidu.com"AutoWebTest().open_web(str)

js滑动脚本解析

const ScrollTop = (number = 0, time) => {if (!time) {document.body.scrollTop = document.documentElement.scrollTop = number;return number;}const spacingTime = 20; // 设置循环的间隔时间  值越小消耗性能越高let spacingInex = time / spacingTime; // 计算循环的次数let nowTop = document.body.scrollTop + document.documentElement.scrollTop; // 获取当前滚动条位置let everTop = (number - nowTop) / spacingInex; // 计算每次滑动的距离let scrollTimer = setInterval(() => {if (spacingInex > 0) {spacingInex--;ScrollTop(nowTop += everTop);} else {clearInterval(scrollTimer); // 清除计时器}}, spacingTime);};

滚动条滑动主要实现在scrollTo方法中,其他方法只是对selenium操作方法的二次封装;

脚本执行调用execute_script方法,值得注意的是,虽然execute_script是同步执行脚本,但执行滑动js脚本,触发定时器方法后,走完后续代码就会返回结果,而不会等定时器(滑动效果)结束;
如果希望方法能等待滑动结束,可通过循环执行js脚本赋值document.body.scrollTop或其他方式实现,也可以像我一样,在后面写个循环不停去判断当前滑动条位置,以此判断滑动动画是否已结束

这篇关于【Python】selenium实现滚动条滑动效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1139359

相关文章

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

Python极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具