selenium页面刷新 xpath无法提取到相应元素

问题遇到的现象和发生背景

在使用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/

没办法登录,看不到具体的页面,不好判断,一般元素找不到的原因如下:

  1. xpath 写错了(需要自行判断)
  2. 页面加载慢, 但看到有 6s 的等待,排除
  3. 是否在新窗口打开页面(如果最需要切换窗口)
  4. 是否存在 frame(如果存在需要切换)

访问这个地址不是直接跳到登录页面吗?并没有找到值为dct3的id

xpath是自己写的?自己写的容易出错,可以打开开发者面板点击要定位的节点,接着右键选择复制,然后选择复制完整xpath路径。将这个路径替换到find_element的路径即可