【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

相关文章

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi