StaleElementReferenceException 当尝试单击循环中的链接时



请点击下面的链接查看我正在点击的"BEAUTY">链接 1.我正在使用此代码单击"美容"链接

driver = webdriver.Chrome("C:\Users\gaurav\Desktop\chromedriver_win32\chromedriver.exe")
driver.maximize_window()
driver.get("http://shop.davidjones.com.au")
object = driver.find_elements_by_name('topCategory')
  for ea in object:
  print ea.text
    if ea.text == 'Beauty':
      ea.click()
  1. 成功点击链接后,我收到以下异常,有人可以告诉我为什么我会得到它吗?

        Traceback (most recent call last):
          File "C:/Users/gaurav/PycharmProjects/RIP_CURL/login_raw.py", line 10, in <module>  
        print ea.text  
          File "C:Python27libsite-packagesseleniumwebdriverremotewebelement.py", line 73, in text  
        return self._execute(Command.GET_ELEMENT_TEXT)['value']  
          File "C:Python27libsite-packagesseleniumwebdriverremotewebelement.py", line 493, in _execute  
        return self._parent.execute(command, params)  
          File "C:Python27libsite-packagesseleniumwebdriverremotewebdriver.py", line 252, in execute  
        self.error_handler.check_response(response)  
          File "C:Python27libsite-packagesseleniumwebdriverremoteerrorhandler.py", line 194, in check_response
        raise exception_class(message, screen, stacktrace)  
        selenium.common.exceptions.StaleElementReferenceException: Message: stale element reference: element is not attached to the page document 
          (Session info: chrome=63.0.3239.132) 
          (Driver info: chromedriver=2.34.522940 (1a76f96f66e3ca7b8e57d503b4dd3bccfba87af1),platform=Windows NT 6.2.9200 x86_64)
    

试试这个:

from selenium import webdriver
print("bot started")
#chromeOptions = webdriver.ChromeOptions()
#driver = webdriver.Chrome(chrome_options=chromeOptions)
def specific_text(text, ea):
    return str(text) == ea.text
driver = webdriver.Chrome("C:\Users\gaurav\Desktop\chromedriver_win32\chromedriver.exe")
driver.maximize_window()
driver.get("http://shop.davidjones.com.au")
object_ = driver.find_elements_by_name('topCategory')
text_headers = [str(specific_text('Beauty', ea)) for ea in object_]
#print(text_headers)
index_text = text_headers.index("True")
#print(index_text)
object_[index_text].click()

您需要注意以下某些因素:

  • 您尝试创建名为 object List object是大多数Programming Languages保留的内置符号。因此,根据Best Programming Practices我们不应该使用名称 object .
  • print ea.text严重缩进。您需要添加缩进。
  • 一旦你在WebElement上调用click()文本作为美女,你需要打破循环。
  • 这是您自己的工作代码,并进行了一些小的调整:

    from selenium import webdriver
    driver = webdriver.Chrome(executable_path=r'C:pathtochromedriver.exe')
    driver.maximize_window()
    driver.get("http://shop.davidjones.com.au")
    object1 = driver.find_elements_by_name('topCategory')
    for ea in object1:
        print (ea.text)
        if ea.text == 'Beauty':
            ea.click()
            break
    
  • 控制台输出 :

    Sale
    Brands
    Women
    Men
    Shoes
    Bags & Accessories
    Beauty
    

有一种更简单的方法可以做到这一点。您可以使用 XPath 来指定要单击的类别名称。这样你就不必循环,它会在一次搜索中找到所需的元素。

//span[@name='topCategory'][.='Beauty']

我假设您将重用此代码。在这种情况下,我会创建一个函数,该函数采用一个字符串参数,该参数将是您要单击的类别名称。将该参数输入到上面的 XPath 中,然后可以单击页面上的任何类别。

我对此进行了测试,它正在工作。

相关内容

  • 没有找到相关文章

最新更新