【发布时间】:2020-08-05 06:57:57
【问题描述】:
我正在制作一个抓取工具来抓取博彩网站的数据,这是一个示例代码,它将抓取赛事、球队和赔率。这个想法是迭代所有可用于这项运动的比赛。我能够找到链接并单击第一个链接,然后我还能够抓取数据并将其返回到列表中(稍后将被放入数据库中)。 我的问题是我无法返回上一页点击下一个链接,尝试执行此操作时出现错误。这是我的代码:
driver = webdriver.Chrome(Path)
driver.get("https://www.neds.com.au/sports/table-tennis/")
a = []
links = driver.find_elements_by_class_name("matches-filter__link")
for l in links:
l.click()
tt_matches = driver.find_elements_by_class_name("sport-event-card")
for match in tt_matches:
Match = match.find_element_by_css_selector(".sports-event-title__name-text").text
a.append(Match)
Teams = match.find_elements_by_css_selector(".price-button")
for team in Teams:
team_name = team.find_element_by_css_selector(".price-button-name").text
team_odd = team.find_element_by_css_selector(".price-button-odds-price span").text
a.append(team_name)
a.append(team_odd)
driver.back()
time.sleep(2)
driver.quit()
它返回此错误:
raise exception_class(message, screen, stacktrace)
StaleElementReferenceException:过时的元素引用:元素是 未附加到页面文档(会话信息: 铬=84.0.4147.105)
我该如何解决这个问题,我认为问题出在 driver.back() 上,我也尝试了 l.back(),但它仍然无法正常工作。
【问题讨论】:
-
我认为您需要在返回页面后重新定义
links。请参阅this 了解更多信息。 -
错误到底发生在哪里?
标签: selenium web-scraping beautifulsoup staleelementreferenceexception