python中selenium等到元素可点击,元素未点击成功解决办法

这篇具有很好参考价值的文章主要介绍了python中selenium等到元素可点击,元素未点击成功解决办法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

环境描述

  • python版本: 3.10.0
  • selenium版本: 3.141.0
  • 浏览器: firefox
  • 浏览器版本: 112.0.1 (64 位)

问题描述

我在使用python中的selenium显示等待等到元素可点击后,点击元素,等到元素可点击了,但是元素没有点击成功。示例代码如下。

from selenium import webdriver
from selenium.webdriver import ActionChains
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.wait import WebDriverWait

with webdriver.Firefox() as driver:
	driver.maximize_window()

	url = "https://www.baidu.com/"
	driver.get(url)

	wait = WebDriverWait(driver, 10)
	locator = By.CSS_SELECTOR, "input#su"
	method = EC.element_to_be_clickable(locator)
	element = wait.until(method)

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

注:以上代码可点击成功,代码仅供参考

问题分析

我认为等到元素可点击,但是没有点击成功有以下几种可能性(仅供参考,欢迎指出问题和补充):

  1. 元素被禁用了,可使用element的is_enabled方法判断元素是否已启用。

  2. 元素被隐藏了,可通过下面的代码判断元素是否被隐藏。

    display_style = element.value_of_css_property("display")
    visibility_style = element.value_of_css_property("visibility")
    if display_style == "none" or visibility_style == "hidden":
        print("元素被隐藏了")
    else:
        print("元素可见")
    

    3.元素被其它元素遮挡了,这也是我遇到的问题,可通过下面的代码判断元素是否被其它元素遮挡。

    is_element_overlapped = self.driver.execute_script("""
                        function isOverlapping(element) {
                            const rect1 = element.getBoundingClientRect();
                            const elements = document.querySelectorAll("*");
                            for (let i = 0; i < elements.length; i++) {
                                const element = elements[i];
                                if (element === rect1) continue;
                                const rect2 = element.getBoundingClientRect();
                                if (
                                    rect1.top < rect2.bottom &&
                                    rect1.bottom > rect2.top &&
                                    rect1.left < rect2.right &&
                                    rect1.right > rect2.left
                                ) {
                                    return true;
                                }
                            }
                            return false;
                        }
                        return isOverlapping(arguments[0]);
    		""", element)
    if is_element_overlapped:
        print("元素被遮挡了")
    else:
        print("元素没有被遮挡")
    

    元素被遮挡点击方法

    解决方法1

    使用js进行点击,代码如下。

    driver.execute_script("arguments[0].click();", element)
    

    解决方法2

    定位到上层元素再将鼠标移动到要点击的元素上。代码如下。

    def click_by_offset(driver: WebDriver, element: WebElement) -> None:
    	""" 鼠标先移动到该元素的父元素上,鼠标再移动到该元素上,然后点击 """
    	# 要点击的元素的位置
    	x, y = element.location.values()
    
    	# 要点击的元素的父元素
    	parent_element = driver.execute_script("return arguments[0].offsetParent;", element)
    
    	assert isinstance(parent_element, WebElement), f"{parent_element}类型错误,应为{WebElement}"
    
    	# 要点击的元素的父元素的位置
    	parent_x, parent_y = parent_element.get_attribute("offsetLeft"), parent_element.get_attribute("offsetTop")
    
    	# 偏移量
    	xoffset, yoffset = x - int(parent_x), y - int(parent_y)
    
    	# 点击
    	ActionChains(driver).move_to_element_with_offset(parent_element, xoffset, yoffset).click().perform()
    

    完整示例代码如下。文章来源地址https://www.toymoban.com/news/detail-786117.html

    from selenium import webdriver
    from selenium.webdriver import ActionChains
    from selenium.webdriver.common.by import By
    from selenium.webdriver.remote.webdriver import WebDriver
    from selenium.webdriver.remote.webelement import WebElement
    from selenium.webdriver.support.wait import WebDriverWait
    from selenium.webdriver.support import expected_conditions as EC
    
    
    def click_by_offset(driver: WebDriver, element: WebElement) -> None:
    	""" 鼠标先移动到该元素的父元素上,鼠标再移动到该元素上,然后点击 """
    	# 要点击的元素的位置
    	x, y = element.location.values()
    
    	# 要点击的元素的父元素
    	parent_element = driver.execute_script("return arguments[0].offsetParent;", element)
    
    	assert isinstance(parent_element, WebElement), f"{parent_element}类型错误,应为{WebElement}"
    
    	# 要点击的元素的父元素的位置
    	parent_x, parent_y = parent_element.get_attribute("offsetLeft"), parent_element.get_attribute("offsetTop")
    
    	# 偏移量
    	xoffset, yoffset = x - int(parent_x), y - int(parent_y)
    
    	# 点击
    	ActionChains(driver).move_to_element_with_offset(parent_element, xoffset, yoffset).click().perform()
    
    
    if __name__ == '__main__':
    	with webdriver.Firefox() as driver:
    		driver.maximize_window()
            
    		url = "https://www.baidu.com"
    		driver.get(url)
            
    		wait = WebDriverWait(driver, 10)
    		locator = By.CSS_SELECTOR, "input#su"
    		method = EC.element_to_be_clickable(locator)
    		element = wait.until(method)
            
    		click_by_offset(driver, element)
    

到了这里,关于python中selenium等到元素可点击,元素未点击成功解决办法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 解决Selenium中无法点击元素,Selemium使用JS代码 driver.execute_script点击元素

    driver.execute_script(\\\"arguments[0].click();\\\",Approved) 这句话的意思是使用 JavaScript 在浏览器中执行一个点击操作,将页面元素 \\\"supportUser\\\" 点击。 具体来说,\\\"driver.execute_script\\\" 是调用浏览器驱动程序 (driver) 的一个方法,它可以用来在浏览器中执行 JavaScript 代码。\\\"arguments[0].click()\\\" 是一段

    2024年02月05日
    浏览(26)
  • selenium元素等待及滚动条滚动

    selenium三大等待,sleep(强制)、implicitlyWait(隐式等待)、WebDriverWait(显式等待),主要记一下最后面的WebDriverWait。 WebDriverWait是三大等待中最常用也是最好用的一种等待方式,比起另外两种而言,B格更高、更智能。写法为: 在iframe中也可以使用WebDriverwait,例如: 例子中

    2024年02月13日
    浏览(38)
  • 【爬虫】5.6 Selenium等待HTML元素

    目录 任务目标 创建Ajax网站 创建服务器程序 Selenium XX 等待 1. Selenium强制等待 2. Selenium隐性等待 3. Selenium循环等待 4. Selenium显示等待 等待方法 在浏览器加载网页的过程中,网页的有些元素时常会有延迟的现象,在HTML元素还没有准备好的情况下去操作这个HTML元素必然会出现错

    2024年02月10日
    浏览(27)
  • selenium+python:点击元素、alert弹框、鼠标操作(左键点击、右键点击、双击、鼠标悬浮)、下拉选项框、窗口切换等操作的处

    driver=webdriver.Chrome() driver.maximize_window() driver.get(\\\"https://www.baidu.com/\\\") 在进行页面操作时,需要用鼠标进行左键点击、右键点击、双击、鼠标悬浮(比如鼠标移到某个位置就会出现一些元素)、鼠标拖动等操作,这时需要导入ActionChains模块 perform() 执行所有ActionChains 中存储的行为

    2024年02月05日
    浏览(47)
  • 【selenium】自动化测试中,元素无法点击定位等问题的解决:js的使用方法

    在自动化测试中经常会遇到使用selenium方法定位元素点击操作失败的情况,例如,我们想实现在浏览器输入http://www.baidu.com,进入百度首页后,鼠标悬停在“更多产品”上,点击“全部产品” 若不使用js的话,代码应该如下图所示: 我们执行代码后,发现会报错 我们该如何解

    2024年02月08日
    浏览(28)
  • RobotFrameWork - 08 - Selenium API - 元素相关操作、注释、休眠及等待元素出现

    元素相关操作 Input Text Click Element Click Button 注释 注释1 — Comment 注释2 — # 休眠及等待元素出现 Sleep Wait Until Page Contains Element 元素相关操作 Input Text 文本输入 Xpatt=//*[@]表示元素定位,定位文本输入框。 附:关于元素定位,参考“Selenium Xpath 定位详解.pdf”文档。 WebDriver基础

    2024年04月22日
    浏览(20)
  • 学习selenium+python使用 XPath 表达式来实现找到目标元素时智能封装等待,执行测试代码启动Chrome浏览器后,地址栏只显示data;

    学习使用 XPath 表达式来实现找到目标元素时智能封装等待 执行测试代码启动Chrome浏览器后,地址栏只显示 data; 看了好久找到了替代启动浏览器的方法:换成 self.driver.get(\\\'http://localhost:8080\\\') 就好了 然后开始琢磨两者的区别: 使用 self.driver.get(\\\'http://localhost:8080\\\') 时,driver 是

    2024年01月17日
    浏览(32)
  • python安装pandas库,安装不成功原因分析及解决办法

    提示:pandas模块是基于Numpy模块开发的,它不仅能直观地展示数据的结构,还具备强大的数据处理和分析的功能。 pandas模块是基于Numpy模块开发的,它不仅能直观地展示数据的结构,还具备强大的数据处理和分析的功能,所以后面会用到该模块库,但是在利用常用的命令pip

    2024年02月04日
    浏览(31)
  • selenium点击多个xpath一样的元素

    如图多个元素的xpath路径是一样的,如何依次点击每个元素呢?  需要用find_element函数,用By进行定位。获取到的是一个list 然后用for循环对list进行遍历 需要注意的是find_elements是不能直接使用click()函数的,遍历时才能用click()  

    2024年02月14日
    浏览(27)
  • Selenium(一)7.元素操作的点击,输入和清除

    Click,SendKeys,Clear Click::模拟鼠标左键,点击元素 SebdKeys:输入内容 Clear:清除元素 应用: 总结: 大部分方法都是围绕Click,SendKeys这两个使用频率最高的事件服务。

    2024年02月16日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包