如何解决Python 3.9.1 API 调用 Tiingo 在某些代码上失败
提前感谢您对我当前的挑战提供的任何见解。我正在运行 Python 3.9.1 以及最新版本的 PANDAS 和 tiingo 库。
问题是某些代码的可靠 API 调用开始失败。我认为问题出在 API 提供者身上,但奇怪的是没有其他人报告这些问题。
我的(简化)代码:
# Loads historical stock data into files
import datetime
#from pandas_datareader import data
import pandas as pd
import io
import os
#import requests
from tiingo import tiingoClient
os.environ["tiingo_API_KEY"] = 'MY API KEY'
client = tiingoClient()
ticker = 'PG'
last_load_date = '2020-08-19'
today = '2021-02-12'
#idx = client.get_dataframe(ticker,frequency='daily',startDate=last_load_date,endDate=today)
##history = client.get_dataframe(['GOOGL',],## frequency='daily',## metric_name='adjClose',## startDate='2020-01-01',## endDate='2021-05-31')
prices = client.get_ticker_price(ticker,fmt='json',endDate=today,frequency='daily')
失败的输出:
Traceback (most recent call last):
File "V:/woodstock/jobs/tiingo_test.py",line 22,in <module>
prices = client.get_ticker_price(ticker,File "C:\Users\wood\AppData\Local\Programs\Python\python39\lib\site-packages\tiingo\api.py",line 241,in get_ticker_price
return response.json()
File "C:\Users\wood\AppData\Local\Programs\Python\python39\lib\site-packages\requests\models.py",line 900,in json
return complexjson.loads(self.text,**kwargs)
File "C:\Users\wood\AppData\Local\Programs\Python\python39\lib\json\__init__.py",line 346,in loads
return _default_decoder.decode(s)
File "C:\Users\wood\AppData\Local\Programs\Python\python39\lib\json\decoder.py",line 337,in decode
obj,end = self.raw_decode(s,idx=_w(s,0).end())
File "C:\Users\wood\AppData\Local\Programs\Python\python39\lib\json\decoder.py",line 355,in raw_decode
raise JSONDecodeError("Expecting value",s,err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
我尝试了直接 JSON 方法(上面)和利用数据帧(首选但上面注释掉)。这适用于 GE 这样的股票代码,但不适用于 PG、TSLA 等。
谢谢!
解决方法
Tiingo 支持非常快速且专业地回答了我的问题。作为“免费”客户,我对他们的服务印象深刻。
对于其他面临此问题的人来说,答案是 Tiingo 对每小时的调用次数和请求的唯一符号总数有限制。 API 失败,因为我已达到 500 个股票代码限制,并且正在请求该列表之外的股票代码。我将升级我的服务来解决这个问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。