小丫么小二郎~
2021-07-15 16:48
采纳率: 66.7%
浏览 41
已结题

python+selenium报not attached to the page document

如图
img

想要对这么一个下拉列表嵌套树结构进行遍历
先从获得下拉框城市列表,用for循环遍历点击,每个城市下的树里都有多个元素,嵌套for循环继续遍历,但是在点击后需要继续执行一些操作导致页面刷新报错element is not attached to the page document!
代码如下:

driver.find_element(By.CSS_SELECTOR,"下拉框").click()  # 点击下拉框
city_arr = driver.find_elements_by_css_selector("城市列表")  # 获取城市列表
# print('city_arr=',city_arr)
for city in city_arr:
            driver.execute_script("arguments[0].click();", city)
            time.sleep(1)
            D=len(driver.find_elements_by_css_selector("#trainingMapTree > div > .el-tree-node") )
            print(D)
            for i in range(D):
                maps = driver.find_elements_by_css_selector("#trainingMapTree > div > .el-tree-node")  # 获取城市下maps列表
                print('maps=', maps[i])
                print(i)
                maps[i].click()  # 点击地图名称
                time.sleep(2)
                driver.find_element_by_css_selector("操作A").click() 
                time.sleep(2)
                driver.find_element_by_css_selector("操作B").click()  
                time.sleep(2)
                driver.find_element(By.CSS_SELECTOR, "操作C").click()  
                time.sleep(2)
                driver.find_element_by_css_selector(".button-group-box > .el-button--primary > span").click()  # 返回
                time.sleep(2)

由于点击操作C后再返回到这个页面的时候,页面已经被刷新了,报错element is not attached to the page document,该怎么办,求解!

  • 好问题 提建议
  • 收藏

2条回答 默认 最新

  • renminzdb 2021-07-20 17:40
    已采纳

    不管什么 都要遵循浏览器的渲染 你执行的操作 肯定是基于你用浏览器操作的一个结果,不能违背这个原则的。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • 有问必答小助手 2021-07-16 14:49

    你好,我是有问必答小助手,非常抱歉,本次您提出的有问必答问题,技术专家团超时未为您做出解答

    本次提问扣除的有问必答次数,将会以问答VIP体验卡(1次有问必答机会、商城购买实体图书享受95折优惠)的形式为您补发到账户。

    ​​​​因为有问必答VIP体验卡有效期仅有1天,您在需要使用的时候【私信】联系我,我会为您补发。

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题