0

我正在尝试编写一个 python 脚本以使用以下链接中的“下载 CSV”按钮自动下载 csv: https ://chartink.com/screener/copy-supertrend-negative-breakout-1103

from selenium import webdriver
import pandas as pd

DRIVER_PATH = r"C:\Users\u123456\Downloads\chromedriver\chromedriver.exe"
d = webdriver.Chrome(executable_path=DRIVER_PATH)
d.get('https://chartink.com/screener/copy-supertrend-negative-breakout-1103')
download_button = pd.read_html(d.find_element_by_class_name('btn btn-default buttons-excel buttons-html5 btn-primary'))[0]
#table = pd.read_html(d.find_element_by_id('DataTables_Table_0').get_attribute('outerHTML'))[0]
print(download_button)

我没有找到有关如何单击该按钮并将其下载到本地驱动器的任何线索。任何帮助将不胜感激。

编辑:我尝试了下面的代码并让它工作,现在我想知道我们是否可以找到文件名并将其加载到熊猫数据框中。

element = d.find_element_by_link_text("Download csv")
element.click()

谢谢,mc

4

1 回答 1

0

要单击元素Download csv,您可以使用以下任一定位器策略

  • 使用link_text

    driver.find_element_by_link_text("Download csv").click()
    
  • 使用css_selector

    driver.find_element_by_css_selector("a.btn.btn-default.buttons-excel.buttons-html5.btn-primary[value='Download backtest']").click()
    
  • 使用xpath

    driver.find_element_by_xpath("//a[@value='Download backtest' and text()='Download csv']").click()
    

理想情况下,要单击需要诱导WebDriverWait的元素element_to_be_clickable(),您可以使用以下任一Locator Strategies

  • 使用LINK_TEXT

    WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.LINK_TEXT, "Download csv"))).click()
    
  • 使用CSS_SELECTOR

    WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.CSS_SELECTOR, "a.btn.btn-default.buttons-excel.buttons-html5.btn-primary[value='Download backtest']"))).click()
    
  • 使用XPATH

    WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.XPATH, "//a[@value='Download backtest' and text()='Download csv']"))).click()
    
  • 注意:您必须添加以下导入:

    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support import expected_conditions as EC
    
于 2020-12-07T11:14:15.377 回答