selenium.common.exceptions.NoSuchElementException

文章讲述了在使用Selenium进行网页爬虫时遇到NoSuchElementException异常的解决过程。作者发现问题出在登录后的新窗口没有被自动切换,通过使用`switch_to.window`方法切换到新窗口解决了问题。此外,文中还提到了使用隐式等待、ChroPath插件等辅助工具。
摘要由CSDN通过智能技术生成

selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element

最近刚刚学习爬虫,遇到了这个问题,上网找了很多方法,比如因为iframe啊,网站没有加载出来需要使用sleep啊,或者使用隐式等待啊。后来还下载了chropath(这是一个抓取xpath路径的插件,详情请自己百度。),但是都没有解决问题。

后来我发现,因为我写的爬虫需要登录,登录之后是另一个网页(窗口),然而在selenium眼中,新窗口默认是不切换过来的。所以需要使用switch_to.window,如下:

web=webdriver.Edge()
web.implicitly_wait(10)
web.get('https://www.jd.com/')
while True:
    if web.find_element(By.LINK_TEXT,'你好,请登录'):
        web.find_element(By.LINK_TEXT,'你好,请登录').click()
        time.sleep(10)
        break
time.sleep(2)
# 点击购物车
while True:
    if web.find_element(By.XPATH,'//*[@id="settleup"]/div[1]/a'):
        web.find_element(By.XPATH,'//*[@id="settleup"]/div[1]/a').click()
        break
web.switch_to.window(web.window_handles[-1])# 这里的-1表示selenium切换到第几个窗口。
time.sleep(2)
# 全选
while True:
    if web.find_element(By.XPATH,'//*[@id="cart-body"]/div[2]/div[3]/div[1]/div'):
        web.find_element(By.XPATH,'//*[@id="cart-body"]/div[2]/div[3]/div[1]/div').click()
        break

虽然这个问题很简单,但是我还是花了不少时间,所以写出来希望帮助像我一样的小白避坑。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值