我在python中使用yahoo_finance来提取股票数据,由于某种原因,该get_prev_close()方法不会在每次调用时返回相同的数据.
这是一个简单的例子:
from yahoo_finance import Share
from time import sleep
while True:
stock = Share('XLV')
prevClose = float(stock.get_prev_close())
print prevClose
sleep(1)
Run Code Online (Sandbox Code Playgroud)
出于某种原因,这将看似随机打印两个不同的数字.因此,今天我得到69.3并69.71打印出来.但由于这是昨天关闭的数据,因此应该只有一个值.
这是已知的错误,有没有办法解决这个问题?
yahoo_finance 包使用的实时 YQL 数据似乎已过时。69.71 是 5 月 11 日的收盘价。正确的值应该是 69.3。
简单的解决方案是访问与中相同的包的历史数据表
>>> from yahoo_finance import Share
>>> stock = Share('XLV')
>>> data, = stock.get_historical('2016-05-12','2016-05-12')
>>> data['Close']
69.300003
Run Code Online (Sandbox Code Playgroud)
或者,直接从雅虎/财经网站获取收盘数据。(更快、更灵活)当尝试复制您的情况时,我没有看到您报告的值的闪烁,但我确实得到了陈旧的关闭(5 月 20 日而不是 5 月 23 日)。也许您看到的闪烁是由于 YQL 有时会访问具有陈旧数据的服务器,有时则不会。下面的代码从 yahoo_finance 的历史数据 (a)、从 yahoo_finance 的实时数据 (b)、直接从 yahoo-finance 实时报价 (c) 以及直接从 yahoo-finance 历史数据获取前一收盘价 ( d).
import csv
import time
import datetime
import requests
import pytz
from yahoo_finance import Share
hist_url = 'http://real-chart.finance.yahoo.com/table.csv?s=XLV&a=4&b=23&c=2016&g=d&ignore.csv'
realtime_url = 'http://download.finance.yahoo.com/d/quotes.csv?s=XLV&f=p&e=.csv'
eastern = pytz.timezone('US/Eastern')
while True:
stock = Share('XLV')
a = stock.get_historical('2016-05-23','2016-05-23')[0]['Close']
b = stock.get_prev_close()
r = requests.get(hist_url)
reader = csv.DictReader(r.iter_lines())
c = float(next(reader)['Close'])
d = float(requests.get(realtime_url).text)
print datetime.datetime.now(eastern).time(), a, b, c, d
time.sleep(120)
Run Code Online (Sandbox Code Playgroud)
第三列中 stock.get_prev_close() 的收盘价始终过时,而其他数字根据以下输出是正确的:
09:24:51.582532 69.410004 69.69 69.410004 69.41
09:26:52.749902 69.410004 69.69 69.410004 69.41
09:28:54.589506 69.410004 69.69 69.410004 69.41
09:30:56.681914 69.410004 69.69 69.410004 69.41
09:32:58.255181 69.410004 69.69 69.410004 69.41
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
862 次 |
| 最近记录: |