如何强制服务器直接从
curl
页面通过 Python 中的 url_historical_data
向我发送查询数据,如示例所示。我已经尝试过不同的事情,但是在传递查询参数时我必须做错一些事情。我想不通。在 64 位 PC 上运行 Windows curl
。请帮忙?
from subprocess import run, PIPE
from htmlement import HTMLement
from json import dumps
def get_data(tabel):
try:
thead = tabel.find("thead")
trh = thead.find("tr")
header = []
cnt = 0
for th in trh:
tmp = th.find('div').find('button').find('span')
header.append(tmp.text)
cnt += 1
print(header)
body = tabel.find("tbody")
for tr in body.findall("tr"):
row = []
cnt = 0
for td in tr:
if cnt == 0:
tijd = td.find('time')
row = [tijd.text]
else:
row.append(td.text)
cnt += 1
print(row)
except:
print('table ; data ; invalid')
return
def get_document(val):
url = f'https://www.investing.com{val}-historical-data'
print('url:', url)
params = {"from_date": "07/01/2024", "to_date": "08/31/2024", "interval": "Daily"}
cnfg = ['curl.exe', '-s', '-A ' + 'Chrome/91.0.4472.114', '-H Content-Type: application/json', '-d ' + dumps(params), url]
print('config:', cnfg, chr(10))
htm_doc = run(cnfg, stdout=PIPE).stdout.decode('utf-8')
try:
parser = HTMLement("table", attrs={"class": "freeze-column-w-1 w-full overflow-x-auto text-xs leading-4"})
parser.feed(htm_doc)
table = parser.close()
get_data(table)
except:
print('html ; table ; invalid')
return
if __name__ == '__main__':
get_document('/equities/aarons')
exit()
上面的python脚本将返回默认输出,而不是返回查询数据的输出:
url: https://www.investing.com/equities/aarons-historical-data
config: ['curl.exe', '-s', '-A Chrome/91.0.4472.114', '-H Content-Type: application/json', "-d {'st_date': '07/01/2024', 'end_date': '08/31/2024', 'interval_sec': 'Daily', 'action': 'historical_data'}", 'https://www.investing.com/equities/aarons-historical-data']
['Date', 'Price', 'Open', 'High', 'Low', 'Vol.', 'Change %']
['Sep 03, 2024', '10.00', '9.97', '10.08', '9.83', '2.96M', '-0.89%']
['Aug 30, 2024', '10.09', '10.09', '10.10', '10.09', '257.67K', '0.00%']
['Aug 29, 2024', '10.09', '10.10', '10.10', '10.09', '237.03K', '0.00%']
['Aug 28, 2024', '10.09', '10.09', '10.11', '10.08', '729.33K', '+0.20%']
['Aug 27, 2024', '10.07', '10.08', '10.09', '10.07', '313.87K', '-0.10%']
['Aug 26, 2024', '10.08', '10.09', '10.10', '10.08', '349.82K', '+0.10%']
['Aug 23, 2024', '10.07', '10.09', '10.11', '10.07', '879.99K', '0.00%']
['Aug 22, 2024', '10.07', '10.08', '10.10', '10.07', '599.27K', '-0.20%']
['Aug 21, 2024', '10.09', '10.09', '10.10', '10.08', '376.91K', '+0.10%']
['Aug 20, 2024', '10.08', '10.09', '10.09', '10.08', '484.85K', '0.00%']
['Aug 19, 2024', '10.08', '10.08', '10.10', '10.07', '1.04M', '+0.10%']
['Aug 16, 2024', '10.07', '10.08', '10.09', '10.07', '827.66K', '-0.10%']
['Aug 15, 2024', '10.08', '10.08', '10.09', '10.06', '776.58K', '+0.20%']
['Aug 14, 2024', '10.06', '10.08', '10.10', '10.06', '655.35K', '0.00%']
['Aug 13, 2024', '10.06', '10.04', '10.10', '10.04', '1.39M', '+0.50%']
['Aug 12, 2024', '10.01', '10.03', '10.04', '10.01', '463.42K', '-0.10%']
['Aug 09, 2024', '10.02', '10.01', '10.02', '10.00', '738.52K', '0.00%']
['Aug 08, 2024', '10.02', '10.04', '10.04', '10.00', '214.86K', '+0.20%']
['Aug 07, 2024', '10.00', '10.00', '10.06', '9.99', '590.25K', '-0.40%']
['Aug 06, 2024', '10.04', '9.96', '10.09', '9.95', '747.36K', '+0.70%']
['Aug 05, 2024', '9.97', '9.96', '10.02', '9.95', '1.23M', '-0.60%']
Process finished with exit code 0
您想要通过定义
from_date
和 to_date
获取的数据不在您请求的 url https://www.investing.com/equities/aarons-historical-data
的首页上。
您必须向
https://api.investing.com/api/financialdata/historical/39136?start-date=2024-07-01&end-date=2024-08-31&time-frame=Daily&add-missing-rows=false
发出请求,该请求由首页上的脚本触发。
此API中的名称
39136
是您访问的股票的id,您可以在instrument_id
标签中找到它定义为<script id="__NEXT_DATA__" type="application/json">
。