python-3.x - 如何从不断刷新网页元素的网页中循环元素

标签 python-3.x selenium

我需要遍历网页的元素并从每个元素中提取数据,但是网络元素每 25 秒刷新一次,我的代码没有在这段时间内完成对所有元素的迭代,在那一刻之后我得到了元素未附加到页面文档错误:

driver.get("https://www.luckia.es/apuestas")
time.sleep(5)
driver.switch_to.frame("sbtechBC")
eventos_de_hoy=driver.find_element_by_id("today_event_btn")
eventos_de_hoy.click()
time.sleep(7)
ligi = driver.find_elements_by_class_name("leagueWindow ")
print(len(ligi))
for items in ligi:
    driver.execute_script("arguments[0].scrollIntoView(true);", items)
    nume_liga= items.find_element_by_tag_name("h5")
    print(nume_liga.text)

我完全没有想法。

最佳答案

您可以尝试下面的代码来避免 StaleElementReferenceException 上的脚本中断:

from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import StaleElementReferenceException

driver = webdriver.Chrome()
driver.get("https://www.luckia.es/apuestas")
WebDriverWait(driver, 10).until(EC.frame_to_be_available_and_switch_to_it("sbtechBC"))
eventos_de_hoy = driver.find_element_by_id("today_event_btn")
eventos_de_hoy.click()

ligi_len = len(WebDriverWait(driver, 10).until(EC.presence_of_all_elements_located((By.CLASS_NAME, "leagueWindow "))))
print(ligi_len)
for index in range(ligi_len):
    try:
        item = WebDriverWait(driver, 10).until(EC.presence_of_all_elements_located((By.CLASS_NAME, "leagueWindow ")))[index]
        driver.execute_script("arguments[0].scrollIntoView(true);", item)
        nume_liga = item.find_element_by_tag_name("h5")
        print(nume_liga.text)
    except StaleElementReferenceException:
        item = WebDriverWait(driver, 10).until(EC.presence_of_all_elements_located((By.CLASS_NAME, "leagueWindow ")))[index]
        driver.execute_script("arguments[0].scrollIntoView(true);", item)
        nume_liga = item.find_element_by_tag_name("h5")
        print(nume_liga.text)

关于python-3.x - 如何从不断刷新网页元素的网页中循环元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47376644/

相关文章:

python-3.x - 如何只保留 pdf 文本或图像的注释部分?

python - Django 跨 View 获取上下文数据

python-3.x - Yandex.天气解析

java - 如何在不使用 jenkins 的情况下在 AWS 中运行本地 Selenium 测试脚本

java - 如何在appium中查找元素

python - mypy:是否可以为复杂类型定义快捷方式?

python - 使用 Gunicorn 进行预测时无法解开对象

selenium - 无法通过 type 属性或 xpath 定位登录框

javascript - 如何停止 webdriver 而不导致 Node js 崩溃

selenium - 在 selenium webdriver 中的 "ul"html 代码的 xpath 中出现问题