在使用selenium进行页面的前进返回时,有时会遇到xpath无法提取到元素的情况,我认为是页面产生的缓存过多导致代码程序卡顿,于是加入了refresh()进行刷新页面后,发现相同的xpath路径 却依旧无法爬取到相应元素
try:
btn4 = driver.find_element(By.XPATH,'//*[@id="dct3"]/div')
except:
driver.refresh()
sleep(6)
btn4 = driver.find_element(By.XPATH,'//*[@id="dct3"]/div')
btn4.click()
selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element: {"method":"xpath","selector":"//*[@id="dct3"]/div"}
(Session info: MicrosoftEdge=105.0.1343.25)
在except 的xpath中可以爬取到相应的值
附上网址url?%ra=linkhttp://i.chaoxing.com/
没办法登录,看不到具体的页面,不好判断,一般元素找不到的原因如下:
访问这个地址不是直接跳到登录页面吗?并没有找到值为dct3的id
xpath是自己写的?自己写的容易出错,可以打开开发者面板点击要定位的节点,接着右键选择复制,然后选择复制完整xpath路径。将这个路径替换到find_element的路径即可