我已经编写了一些代码,以便从investing.com抓取BTC / ETH时间序列,并且工作正常。但是,我需要更改请求调用,以使下载的数据来自Kraken而不是bitfinex默认值,而不是从01/06/2016而不是默认的开始时间。可以在网页上手动设置此选项,但是我不知道如何通过请求调用发送该选项,除了它可能涉及使用“ data”参数。感谢任何建议。
谢谢
KM
已经用python编写的代码,可以很好地使用默认值
import requests
from bs4 import BeautifulSoup
import os
import numpy as np
# BTC scrape https://www.investing.com/crypto/bitcoin/btc-usd-historical-data
# ETH scrape https://www.investing.com/crypto/ethereum/eth-usd-historical-data
ticker_list = [x.strip() for x in open("F:\\System\\PVWAVE\\Crypto\\tickers.txt", "r").readlines()]
urlheader = {
"User-Agent": "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.75 Safari/537.36",
"X-Requested-With": "XMLHttpRequest"
}
print("Number of tickers: ", len(ticker_list))
for ticker in ticker_list:
print(ticker)
url = "https://www.investing.com/crypto/"+ticker+"-historical-data"
req = requests.get(url, headers=urlheader, data=payload)
soup = BeautifulSoup(req.content, "lxml")
table = soup.find('table', id="curr_table")
split_rows = table.find_all("tr")
newticker=ticker.replace('/','\\')
output_filename = "F:\\System\\PVWAVE\\Crypto\\{0}.csv".format(newticker)
os.makedirs(os.path.dirname(output_filename), exist_ok=True)
output_file = open(output_filename, 'w')
header_list = split_rows[0:1]
split_rows_rev = split_rows[:0:-1]
for row in header_list:
columns = list(row.stripped_strings)
columns = [column.replace(',','') for column in columns]
if len(columns) == 7:
output_file.write("{0}, {1}, {2}, {3}, {4}, {5}, {6} \n".format(columns[0], columns[2], columns[3], columns[4], columns[1], columns[5], columns[6]))
for row in split_rows_rev:
columns = list(row.stripped_strings)
columns = [column.replace(',','') for column in columns]
if len(columns) == 7:
output_file.write("{0}, {1}, {2}, {3}, {4}, {5}, {6} \n".format(columns[0], columns[2], columns[3], columns[4], columns[1], columns[5], columns[6]))
output_file.close()
已下载数据以进行默认交换和默认日期范围,但我想指定Kraken以及默认开始和结束时间(2016年6月1日以及最后一整天,即始终是昨天)
答案 0 :(得分:2)
许多网站根据用户活动(例如,您填写用户名和密码的登录页面)使用称为 forms 的网站将数据发送到服务器。当您单击按钮时。像这样的事情正在发生。
您需要聪明,并在python代码中进行 3 更改。
将网址更改为您刚在 Headers 标签中看到的网址。
url =“ https://www.investing.com/instruments/HistoricalDataAjax”
payload = {'header':'BTC / USD Kraken历史数据','st_date':'12 / 01/2018','end_date':'12 / 01/2018','sort_col':'date' ,“操作”:“ historical_data”,“ smlID”:“ 145284”,“ sort_ord”:“ DESC”,“ interval_sec”:“每日”,“ curr_id”:“ 49799”}
requests.post(URL,data = payload,headers = urlheader)
进行上述更改,并使代码的其他部分保持不变。您将得到想要的结果。您也可以根据需要修改日期。