python - 如何通过 Python 使用 Selenium 单击联赛列表中的每个项目时防止 StaleElementReferenceException

标签 python selenium-webdriver web-scraping webdriverwait staleelementreferenceexception

在此网站上操作:https://www.livetulokset.com/

my_leagues = browser.find_element_by_id('my-leagues-list') # single element
leagues = my_leagues.find_elements_by_tag_name('li') # list of elements
for i in leagues:
    i.click()   # Click first league
    sleep(1)    # sleep second to be able to see the click in monitor
    browser.find_element_by_css_selector('a.menuTop__item:nth-child(1) > div:nth-child(2)').click() # click football icon

代码单击列表中的第一个联赛,然后单击足球图标返回主页。当尝试单击列表中的第二个联赛时,由于页面刷新而发生 StaleElementReferenceException。如何防止这种情况发生?

编辑:

我真的需要解决方案,以便在 for 循环期间不丢失网络元素。这个足球网站只是为了让你们在行动中测试我的问题。

最佳答案

为什么不直接获取联赛的链接,然后获取它们。如果第一个链接是 links[1:]

的当前链接,您可以跳过该链接
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
url = 'https://www.livetulokset.com/'
driver = webdriver.Chrome()
driver.get(url)
links = [link.get_attribute('href') for link in WebDriverWait(driver,10).until(EC.presence_of_all_elements_located((By.CSS_SELECTOR, "#my-leagues-list a")))]
print(links)
for item in links:
    driver.get(link)
    # do something

关于python - 如何通过 Python 使用 Selenium 单击联赛列表中的每个项目时防止 StaleElementReferenceException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55069388/

相关文章:

python - 提取span标签内的信息

python - 如何抓取 AJAX 网站?

python - 使用 BeautifulSoup4 解析 HTML 表格

python - 在 Pandas 中重新索引和填充 NaN 值

python - 在python中拆分列表的项目

python - 在本地主机上运行 python 脚本

java - 在执行期间检查 WebDriver 测试中的加载时间

python - 无法使用 Python 安装 Selenium WebDriver

python - Pandas 分组并按索引计数排序

python - 有多个类的 Scrapy 抓取 div?