python之selenium操作下拉滚动条方法

devtools/2024/9/24 0:25:19/

前言

①在HTML页面中,由于前端技术框架的原因,页面中的一些元素为动态显示,元素根据滚动条的下拉而被加载(元素在当前显示的页面不可见,拖动页面下拉直到该元素出现,此时才可以定位到该元素。)。

②例如:页面注册同意条款,需要滚动条到最底层,才能点击同意。

实例

下面一个网页,需要进行拖动页面下拉条后才能通过selenium代码找到密码输入框的元素。

拖动页面下拉条后:

方法①:使用JavaScript脚本直接操作滚动条元素向下拖动

注意:这里的id为滚动条的id,但js中没有xpath的方法,所以滚动条没有id的网页此方法不适用。

js = "var q=document.getElementById('id').scrollTop=10000"driver.execute_script(js)

或者:

js = "var q=document.documentElement.scrollTop=10000"driver.execute_script(js)

方法②:使用JavaScript脚本将滚动条拖动到指定地方:

聚焦元素:就是把滚动条滚动到你想要查找的元素的位置

复制代码

# 1 定位需要聚焦元素
target = driver.find_element_xx# 2 js代码
js = "arguments[0].scrollIntoView();"# 3 执行聚焦元素操作
driver.execute_script(js代码, 元素target)

复制代码

注意:使用该方法需要获取将滚动条拖动至指定元素的元素对象定位。

target = driver.find_element_by_id("id_keypair")  # 需要将滚动条拖动至的指定的元素对象定位driver.execute_script("arguments[0].scrollIntoView();", target)  # 将滚动条拖动到元素可见的地方

该方法可以将页面滚动条拖动到需要显示的元素位置,此方法用途比较广,可以使用。

示例:

页面代码:

复制代码

<!DOCTYPE html>
<html lang="zh-cn">
<head><meta charset="UTF-8"><style type="text/css">button{padding: 8px; background: #f8f8f8;border-radius: 5px}button{margin-left:200px;margin-top:2000px}</style>
</head>
<body><button type="submitA" value="注册A" title="加入会员A" >注册用户A</button>
</body>
</html>

复制代码

脚本代码:

复制代码

"""
1.学习目标:掌握聚焦元素的操作方法
2.语法(操作方法)2.1 定位需要聚焦元素target = driver.find_element_xx2.2 js代码js = "arguments[0].scrollIntoView()"2.3 执行聚焦元素操作driver.execute_script(js代码,元素target)
3.需求在页面中,滚动条下拉聚焦元素位置。
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os# 2.打开浏览器
driver = webdriver.Chrome()# 3.打开页面
url = "file:///" + os.path.abspath("./1.html")
driver.get(url)
sleep(2)# 4.滚动条下拉聚焦元素位置
# 4.1 定位需要聚焦元素-淘宝首页的END文字
element = driver.find_element_by_css_selector("[type='submitA']")# 4.2 js代码
js = "arguments[0].scrollIntoView()"# 4.3 执行聚焦元素操作
driver.execute_script(js, element)
sleep(3)# 5.关闭浏览器
driver.quit()

复制代码

方法③:根据页面显示进行变通实现滚动条下拉效果:

在本实例中的页面中,密码是输入框,正常手工操作时,可以通过tab键可以从用户框切换到密码框中,所以根据此思路,在脚本中也可以发送tab键来切换,使元素显示。

from selenium.webdriver.common.keys import Keys  # 导入Keys类driver.find_element_by_id("id_login_method_0").send_keys(Keys.TAB)  # 定位元素并操作输入

方法④:send_keys(Keys.Space) 模拟向页面发送空格键实现滚动条下拉效果:

注意:发送空格键的元素应该是整个页面对象,比如说定位到页面body后进行操作。

复制代码

# coding=utf-8
import timefrom selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.common.exceptions import TimeoutExceptionbrowser = webdriver.Chrome(executable_path="G:/dj/chromedriver.exe")browser.set_window_size(1400, 900)def search():try:browser.get("https://www.taobao.com")for i in range(5):browser.find_element_by_tag_name('body').send_keys(Keys.SPACE)time.sleep(1)except TimeoutException:search()search()

复制代码

方法⑤:鼠标移动到指定元素位置

复制代码

# coding=utf-8
from selenium import webdriver
from selenium.common.exceptions import TimeoutException
from selenium.webdriver.common.action_chains import ActionChainsbrowser = webdriver.Chrome("G:/dj/chromedriver.exe")browser.set_window_size(1400, 900)def search():try:browser.get("https://www.taobao.com")target = browser.find_element_by_css_selector('body > div:nth-child(29)')actions = ActionChains(browser)actions.move_to_element(target)actions.perform()except TimeoutException:search()search()

复制代码

方法⑥:操作滚动条实现

复制代码

"""
设置JavaScritp脚本控制滚动条
"""
js = "window.scrollTo(0, 1000)"  # (0:水平距离;1000:垂直距离;单位像素px)"""
WebDriver调用JavaScritp脚本方法
"""
driver.execute_script(js)# 提示:
"""最顶层"""
js = "window.scrollTo(0,0)""""最底层"""
js = "window.scrollTo(0,1000)"
# 注:1000不代表一定到最底层,要根据浏览器页面的实际大小。"""
直接操作垂直距离的方式
"""
js = "var q=document.documentElement.scrollTop=n"

复制代码

示例:

复制代码

"""
1.学习目标:掌握浏览器滚动条的操作方法
2.语法2.1使用js语言编写控制滚动条代码参数:0,表示水平距离;10000,表示垂直距离  单位:px格式:向下滚动:window.scrollTo(0,10000)向上滚动:window.scrollTo(0,0)2.2使用selenium中方法执行js代码driver.execute_script(js代码)
3.需求在页面中,控制滚动条
4.总结如果需要测试写的js代码,可以在浏览器F12,控制台console中执行查看结果。
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep# 2.打开浏览器
driver = webdriver.Chrome()# 3.打开页面
url = "https://www.taobao.com"
driver.get(url)
sleep(2)# 4.滚动条操作
# 4.1 滚动条向下滚动
js_down = "window.scrollTo(0,1000)"
# 执行向下滚动操作
driver.execute_script(js_down)
sleep(2)# 4.2 滚动条向上滚动
js_up = "window.scrollTo(0,0)"
driver.execute_script(js_up)
sleep(2)# 向下滚动操作
# n为从顶部往下移动滚动距离
js1 = "var q=document.documentElement.scrollTop=2000"
driver.execute_script(js1)
sleep(2)# 5.关闭浏览器
driver.quit()

复制代码

注意:

window.scrollBy(0, 100):从当前位置向下滚动100像素;

window.scrollTo(0,100):从0滚动到100像素,

这两个方法都是滚动操作,但是scrollTo方法只会从0像素滚动到100像素,除非修改数值才可以滚动到对应像素位置,二scrollBy则会一直向下滚动。

复制代码

# coding=utf-8
import timefrom selenium import webdriver
from selenium.common.exceptions import TimeoutExceptiondef search():t = Truetime.sleep(1)while t:driver.execute_script("window.scrollBy(0, 1000)")try:driver.find_element('link_text', '没有更多推荐了,返回首页').click()time.sleep(1)t = Falseexcept TimeoutException:search()if __name__ == '__main__':driver = webdriver.Chrome()driver.get("https://blog.csdn.net/sily_z/article/details/80733267")driver.maximize_window()

复制代码


http://www.ppmy.cn/devtools/100154.html

相关文章

打卡学习Python爬虫第六天|处理cookie登录小说网

引言&#xff1a;一些网站不需要登录就能看到信息&#xff0c;但对于需要登录才能看见信息的网站&#xff0c;我们就需要借助cookie&#xff0c;使爬虫能够顺利登录网站&#xff0c;从而获取所需数据。 1、登录后查看页面源代码 并没有我们需要的数据 2、利用抓包工具 右键--…

Spring框架

spring的整体架构&#xff1a; DefaultListableBeanFactory是整个bean加载的核心部分&#xff0c;它是Spring注册及加载bean的默认实现。 test&#xff1a; bean.xml中有很多bean的定义&#xff1a; <!-- bean 标签演示 --><bean id"m416" class"com…

数论之组合数

组合数1&#xff1a; 预处理每一个组合数的大小 类似于dp&#xff0c;从a个苹果里面选b个出来&#xff1a;首先从a个苹果里面拿出来一个&#xff0c;这样就分成了两种&#xff0c;一种是包括这个拿出来的苹果的方案数&#xff0c;此时就只需要拿b-1个苹果。一种是不包括这种苹…

文件包含漏洞(1)

目录 PHP伪协议 php://input Example 1&#xff1a; 造成任意代码执行 Example 2&#xff1a; 文件内容绕过 php://filer zip:// PHP伪协议 php://input Example 1&#xff1a; 造成任意代码执行 搭建环境 <meta charset"utf8"> <?php error_repo…

【vue运行报错】无法加载文件 D:\nodejs\node_global\webpack.ps1,因为在此系统上禁止运行脚本。

根据这篇博客安装nodejs和vue&#xff0c;执行webpack -v 和vue -v 报错。 Vue安装与配置教程&#xff08;非常详细&#xff09;从零基础入门到精通&#xff0c;看完这一篇就够了-CSDN博客 【解决方法】 &#xff08;1&#xff09;以管理员身份运行终端/命令提示符&#xff…

python模块05-json

3 请求数据提取&#xff1a;json 3.1 json类型数据 json对象&#xff1a;{key:calue} json数组&#xff1a;[1,2,3,4] 3.2 json模块 1&#xff09; json.loads 把Json格式字符串解码转换成Python对象&#xff08;json数组对应列表&#xff0c;json对象对应字典&#xff09…

002 深入了解路由协议:RIP、OSPF和BGP

引言 路由协议决定了数据包在网络中传输的路径选择&#xff0c;了解这些协议的细节是网络工程师的必修课。本篇博文将通过对比RIP、OSPF和BGP三种协议&#xff0c;帮助你选择最适合你网络环境的方案。 1. 路由协议的分类 IGP&#xff08;内部网关协议&#xff09;&#xff1…

RabbitMQ高级用法

&#x1f4a5; 该系列属于【SpringBoot基础】专栏&#xff0c;如您需查看其他SpringBoot相关文章&#xff0c;请您点击左边的连接 目录 一、发送者的可靠性 1. 生产者重试机制 2. 生产者确认机制【return和confirm机制】 &#xff08;1&#xff09;开启生产者确认 &#x…