【Python】selenium 点击某个按钮 click() 出现的报错问题--ElementClickInterceptedException(全!)

写在前面:

我们在使用selenium 点击某个元素时或者获取find_element的某个网页元素时,总会遇到一些问题。本人经验是,最直接的方法是用try_except 报错 ,直接绕过问题,可以直接看第一条。如果有兴趣具体解决,可以看后面的几个方法,赶时间的伙伴可以只看第一条就好了!

我们在Python中使用Selenium库进行自动化测试时,如果遇到点击某个按钮时click()方法出现问题,Selenium会抛出一个异常。如果这个异常是

selenium.common.exceptions.ElementClickInterceptedException

这表明,我们点击的操作被另一个元素拦截了,导致我们点不到我们想要的东西,而是点到别的东西。

解决这个问题,以下有几种方法:

1、try-except捕获异常报错:

个人觉得使用try-except语句来捕获这些异常是最直接和快捷的,将报出的问题捕获到,并给出下一步更具体的提示,去恢复操作,以下是代码的部分:

python 复制代码
#调用selenium的
from selenium.common.exceptions import NoSuchElementException, ElementClickInterceptedException

try:
    element = driver.find_element(By.XPATH,'//*[@id="app"]/main/section[1]/div/div[3]/span')
    element.click()
except ElementClickInterceptedException as e:
    print("点击被拦截,请检查是否有其他元素覆盖在按钮上。")
    #这里可以写遇到这个问题的解决方法,可以报错给自己看,也可以直接忽略到下一步等等。
except NoSuchElementException as e:
    print("找不到元素,请检查元素的定位方式是否正确。")
except Exception as e:
    print(f"发生了一个错误:{e}")

通过捕获特定的异常类型并给出相应的错误信息,在写代码的时候,可以更快速地定位和解决问题。

当这些异常发生时,我们也可以通过编写自定义的错误来捕捉处理这些异常,如果想了解其他的异常Exception类,可以参考:

2、检查覆盖元素,关闭弹窗:

检查并解决覆盖元素: 检查页面上的覆盖元素,并尝试解决它们。

检查我们点击的元素是不是上面有一层覆盖的模态框或弹出窗口,如果有,尝试关闭或隐藏它们,点击关闭的键,例如如图:(图片来自网络)

代码:

python 复制代码
# 假设弹出窗口有一个关闭按钮
close_button = driver.find_element(By.ID, "closeButton")
close_button.click()

如果不是窗口,那么看看是否有关闭下拉菜单、隐藏覆盖层等。具体问题具体分析。如果是有隐藏的覆盖层,需要找到下一层的接口网址。

3、滚动到元素的位置:

如果元素不在可视区域内,在页面底下,要滚动到该元素可以使它变得可点击。

python 复制代码
driver.execute_script("arguments[0].scrollIntoView();", element)

4、使用显式等待,直到元素可以被点击

可能网站显示的速度太慢,需要等到页面加载才会让元素出来,这时候就可以用显性等待的方法。

python 复制代码
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

try:
    element = WebDriverWait(driver, 10).until(
        EC.element_to_be_clickable((By.ID, "myElement"))
    )
    element.click()
except TimeoutException:
    print("元素在指定时间内不可点击")

5、使用ActionChains模拟鼠标移动到元素上再点击

这种情况适用于对方网站的服务器已经检测到了爬虫操作,普通的click不能通过检验,需要点击元素才能让页面加载(当然这种情况其实少见),解决方法:

python 复制代码
from selenium.webdriver.common.action_chains import ActionChains

action = ActionChains(driver)
action.move_to_element(element).click(element).perform()

6、刷新页面:

如果元素应该可见但当前不可见,可能是因为页面状态不正确。尝试刷新页面。

python 复制代码
driver.refresh()

7、使用JavaScript:

通过执行 JavaScript 来点击元素,这可以绕过一些覆盖元素。

python 复制代码
driver.execute_script("arguments[0].click();", element)
相关推荐
Charles_go14 分钟前
C#中级45、什么是组合优于继承
开发语言·c#
不去幼儿园25 分钟前
【启发式算法】灰狼优化算法(Grey Wolf Optimizer, GWO)详细介绍(Python)
人工智能·python·算法·机器学习·启发式算法
二川bro28 分钟前
数据可视化进阶:Python动态图表制作实战
开发语言·python·信息可视化
青青子衿_2143 分钟前
TikTok爬取——视频、元数据、一级评论
爬虫·python·selenium
q***2511 小时前
java进阶1——JVM
java·开发语言·jvm
while(1){yan}1 小时前
线程的状态
java·开发语言·jvm
豐儀麟阁贵1 小时前
8.3 Java常见的异常类
java·开发语言
lzh200409191 小时前
【C++STL】List详解
开发语言·c++
q***44811 小时前
Java进阶10 IO流
java·开发语言
忘却的旋律dw1 小时前
使用LLM模型的tokenizer报错AttributeError: ‘dict‘ object has no attribute ‘model_type‘
人工智能·pytorch·python