如何解决Selenium Python - 如何使用 Selenium 从雅虎财经的历史数据中点击时间段
我在尝试查找时间段的元素时遇到问题。我要做的下一步是选择最大周期,然后下载数据。 我尝试了检查元素,但找不到适合 XPATH 的元素。
这是我的代码
enter code here
import selenium
import time
from selenium.webdriver.common.keys import Keys
from selenium import webdriver
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
caps = DesiredCapabilities().CHROME
caps["pageLoadStrategy"] = "none" # Do not wait for full page load
PATH = "C:\Program Files (x86)\chromedriver.exe"
driver = webdriver.Chrome(PATH)
driver.get("https://finance.yahoo.com/quote/XRP-USD?p=XRP-USD")
time.sleep(2.9)
driver.execute_script("window.stop();")
clickHistorical = driver.find_element_by_xpath('//span[text()= "Historical Data"]')
clickHistorical.click()
time.sleep(3.9)
grabTimePeriod = driver.find_element_by_xpath("HOW TO FIND THE ELEMENT OF THE TIME PERIOD??").click()
解决方法
grabTimePeriod = driver.find_element_by_xpath("//span[contains(text(),'Time Period')]/../..//div/span")
说明:对我来说最好的方法是在 xpath 的帮助下通过文本找到它,因为在这个元素中使用类名:<span class="C($linkColor) Fz(14px)">Apr 13,2020 - Apr 13,2021</span>
不稳定。
另外,导入:
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By as By
在点击之前等待这个定位器。
wait.until(EC.element_to_be_clickable(
(By.XPATH,"//span[contains(text(),'Time Period')]/../..//div/span")))
grabTimePeriod = driver.find_element_by_xpath("//span[contains(text(),'Time Period')]/../..//div/span")
grabTimePeriod.click()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。