【Python】selenium结合js模拟鼠标点击、拦截弹窗、鼠标悬停方法汇总(使用 execute_script 执行点击的方法)

embedded/2025/1/8 20:01:05/

我们在写selenium获取网络信息的时候,有时候我们会受到对方浏览器的监控,对方通过分析用户行为模式,如点击、滚动、停留时间等,网站可以识别出异常行为,进而对Selenium爬虫进行限制。

这里我们可以加入JavaScript的使用。Selenium可以执行JavaScript,通过使用 execute_script 方法,来执行点击操作。

它可以绕过一些 Selenium 直接操作元素时可能遇到的问题,比如元素未完全加载元素被遮挡或者需要更复杂的交互。

以下是几种使用 execute_script 来执行点击操作的方法:

1. 模拟鼠标直接点击事件

python">element = driver.find_element_by_id("myButton")
driver.execute_script("arguments[0].click();", element)

这段代码找到 ID 为 myButton 的元素,并使用 JavaScript 直接触发该元素的点击事件。

2. 拦截弹出窗口

通过覆盖浏览器内置的方法,如alert、confirm、prompt等,避免弹出窗口

python">driver.execute_script('''window.alert = function() {console.log("Alert function called, but blocked.");
};
window.confirm = function() {console.log("Confirm function called, but blocked.");return true; // 返回true,以模拟用户点击“确定”按钮
};
window.prompt = function() {console.log("Prompt function called, but blocked.");return null; // 返回null,以模拟用户点击“取消”按钮
};''')

以上的代码,所有调用alert、confirm和prompt的方法将被拦截,且不会弹出任何窗口。这种方法简单而有效,适用于大多数情况。

3. 创建并派发点击事件

这种方法创建一个新的点击事件,并将其派发到指定的元素上,这可以提供更多的控制,比如模拟鼠标右键点击。

python">element = driver.find_element("myButton")
driver.execute_script("var event = new MouseEvent('click', {""view: window,""bubbles: true,""cancelable: true});""arguments[0].dispatchEvent(event);", element)

在运行过程中,如果遇到下面的问题:

“JavascriptException: javascript error: arguments[0].dispatchEvent is not a function”

这说明,

4. 使用 JavaScript 模拟鼠标悬停后点击

如果你需要更复杂的鼠标操作,比如鼠标悬停后点击,你可以使用以下方法:

python">element = driver.find_element_by_id("myButton")
driver.execute_script("arguments[0].style.cursor = 'pointer';", element)
driver.execute_script("arguments[0].onmouseover = function() {""arguments[0].style.backgroundColor = 'yellow'; };", element)
driver.execute_script("arguments[0].onmouseout = function() {""arguments[0].style.backgroundColor = 'white'; };", element)
driver.execute_script("arguments[0].click();", element)

5. 滚动到元素并点击

如果元素不在可视区域内,你可能需要先滚动到该元素,然后再执行点击操作:

python">element = driver.find_element_by_id("myButton")
driver.execute_script("arguments[0].scrollIntoView();", element)
driver.execute_script("arguments[0].click();", element)

6. 等待元素可点击后执行点击

有时候,元素可能需要一些时间来加载或变得可点击,你可以使用 execute_script 来等待这个条件:

python">element = driver.find_element_by_id("myButton")
driver.execute_script("while (arguments[0].disabled || ""arguments[0].style.display === 'none' || ""arguments[0].style.visibility === 'hidden') {""setTimeout(function() {}, 100); };""arguments[0].click();", element)

这些方法提供了不同场景下使用 execute_script 执行点击操作的示例。

你可以根据实际情况选择最适合你需求的方法。


http://www.ppmy.cn/embedded/151287.html

相关文章

HTML——16.相对路径

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title></head><body><a href"../../fj1/fj2/c.html" target"_blank">链接到c</a><!--相对路径&#xff1a;-->…

Flume的安装和使用

一、安装Flume 1. 下载flume-1.7.0 http://mirrors.shu.edu.cn/apache/flume/1.7.0/apache-flume-1.7.0-bin.tar.gz 2. 解压改名 tar xvf apache-flume-1.7.0-bin.tar.gz mv apache-flume-1.7.0-bin flume 二、配置Flume 1. 配置sh文件 cp conf/flume-env.sh.template …

UML之组合与聚合

关联和链接关系在很多情况下是对称的&#xff0c;即被关联的两个类都有以自己为源端对方为目标端的角色存在&#xff0c;而且角色与源端类的属性是等价的&#xff0c;即在关联一端的关联端&#xff08;角色&#xff09;等价于另外一端的属性。例如&#xff0c;在下图中&#xf…

51.第二阶段x86游戏实战2-继续寻找lua

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 本次游戏没法给 内容参考于&#xff1a;微尘网络安全 本人写的内容纯属胡编乱造&#xff0c;全都是合成造假&#xff0c;仅仅只是为了娱乐&#xff0c;请不要…

【每日学点鸿蒙知识】PersistentStorage持久化、插槽方法、相对布局、上拉加载下拉刷新、List联动滑动

1、HarmonyOS 使用PersistentStorage持久化用户信息无效&#xff1f; 在首页通过StorageLink(‘userInfoTest’) userInfoTest: string 获取&#xff0c;获不到&#xff0c;返回undefind。是什么原因呢&#xff1f; 首先在首页时&#xff0c;在Entry外声明PersistentStorage…

NLP初识

目录 0简介一、自然语言概述1. 什么是NLP?2. NLP常用工具0简介 NLP系列开始更新了!!!这个系列主要会介绍一些NLP的基础概念,比如RNN、LSTM、GRU等内容,重头戏放在大语言模型的基础讲解上,其中大语言模型的分享主要由两个方面:1.基础结构(Seq2Seq,Attention,Transfor…

《Vue3实战教程》19:Vue3组件 v-model

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 组件 v-model​ 基本用法​ v-model 可以在组件上使用以实现双向绑定。 从 Vue 3.4 开始&#xff0c;推荐的实现方式是使用 defineModel() 宏&#xff1a; vue <!-- Child.vue --> <script setup> co…

图文检索(37):局部对齐Stacked Cross Attention for Image-Text Matching

Stacked Cross Attention for Image-Text Matching 摘要引言方法3.1 stacked cross attention3.2 alignment objective3.3 representing images with bottom-up attention3.4 representing sentences 结论 发布时间&#xff08;2018 ECCV&#xff09; 标题&#xff1a;用于图像…