Python 3.9.1 API 调用 Tiingo 在某些代码上失败
Python 3.9.1 API call to Tiingo failing on certain tickers
非常感谢您对我当前的挑战提供的任何见解。我是 运行 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',
startDate=last_load_date,
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 支持非常快速和专业地回答了我的问题。作为“免费”客户,他们的服务给我留下了深刻的印象。
对于其他面临此问题的人来说,答案是 Tiingo 对每小时调用次数和请求的唯一符号总数有限制。 API 失败是因为我已经达到了我的 500 个代码限制并且正在请求该列表之外的代码。我将升级我的服务来解决这个问题。
非常感谢您对我当前的挑战提供的任何见解。我是 运行 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',
startDate=last_load_date,
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 支持非常快速和专业地回答了我的问题。作为“免费”客户,他们的服务给我留下了深刻的印象。
对于其他面临此问题的人来说,答案是 Tiingo 对每小时调用次数和请求的唯一符号总数有限制。 API 失败是因为我已经达到了我的 500 个代码限制并且正在请求该列表之外的代码。我将升级我的服务来解决这个问题。