Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/366.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 当开始日期或结束日期为当前日期时,返回Yahoo Datareader RemoteDataError_Python_Pandas_Stocks_Pandas Datareader - Fatal编程技术网

Python 当开始日期或结束日期为当前日期时,返回Yahoo Datareader RemoteDataError

Python 当开始日期或结束日期为当前日期时,返回Yahoo Datareader RemoteDataError,python,pandas,stocks,pandas-datareader,Python,Pandas,Stocks,Pandas Datareader,我正在运行以下程序来提取股票信息: import datetime import pandas as pd from pandas import DataFrame from pandas.io.data import DataReader symbols_list = ['AAPL', 'TSLA', 'YHOO','GOOG', 'MSFT','ALTR','WDC','KLAC'] symbols=[] for ticker in symbols_list: r = DataR

我正在运行以下程序来提取股票信息:

import datetime
import pandas as pd
from pandas import DataFrame
from pandas.io.data import DataReader
symbols_list = ['AAPL', 'TSLA', 'YHOO','GOOG', 'MSFT','ALTR','WDC','KLAC']

symbols=[]
for ticker in symbols_list: 
    r = DataReader(ticker, "yahoo", 
                   start=datetime.datetime(2015, 4, 17))
    # add a symbol column
    r['Symbol'] = ticker 
    symbols.append(r)
# concatenate all the dfs
df = pd.concat(symbols)
#define cell with the columns that i need
cell= df[['Symbol','Open','High','Low','Adj Close','Volume']]
#changing sort of Symbol (ascending) and Date(descending) setting Symbol as first column and changing date format
cell.reset_index().sort(['Symbol', 'Date'], ascending=[1,0]).set_index('Symbol').to_csv('stock.csv', date_format='%d/%m/%Y')
这个运行得很好。但当我将开始日期更改为今天,即2015年4月20日时,程序就会出错。我也试过给出截止日期,但没有用。下面是我得到的错误:

UnboundLocalError                         Traceback (most recent call last)
<ipython-input-38-a05c721d551a> in <module>()
      8 for ticker in symbols_list:
      9     r = DataReader(ticker, "yahoo", 
---> 10                    start=datetime.datetime(2015, 4, 20))
     11     # add a symbol column
     12     r['Symbol'] = ticker

/usr/local/lib/python2.7/site-packages/pandas/io/data.pyc in DataReader(name, data_source, start, end, retry_count, pause)
     75         return get_data_yahoo(symbols=name, start=start, end=end,
     76                               adjust_price=False, chunksize=25,
---> 77                               retry_count=retry_count, pause=pause)
     78     elif data_source == "google":
     79         return get_data_google(symbols=name, start=start, end=end,

/usr/local/lib/python2.7/site-packages/pandas/io/data.pyc in get_data_yahoo(symbols, start, end, retry_count, pause, adjust_price, ret_index, chunksize, interval)
    418         raise ValueError("Invalid interval: valid values are 'd', 'w', 'm' and 'v'")
    419     return _get_data_from(symbols, start, end, interval, retry_count, pause,
--> 420                           adjust_price, ret_index, chunksize, 'yahoo')
    421 
    422 

/usr/local/lib/python2.7/site-packages/pandas/io/data.pyc in _get_data_from(symbols, start, end, interval, retry_count, pause, adjust_price, ret_index, chunksize, source)
    359     # If a single symbol, (e.g., 'GOOG')
    360     if isinstance(symbols, (compat.string_types, int)):
--> 361         hist_data = src_fn(symbols, start, end, interval, retry_count, pause)
    362     # Or multiple symbols, (e.g., ['GOOG', 'AAPL', 'MSFT'])
    363     elif isinstance(symbols, DataFrame):

/usr/local/lib/python2.7/site-packages/pandas/io/data.pyc in _get_hist_yahoo(sym, start, end, interval, retry_count, pause)
    206            '&g=%s' % interval +
    207            '&ignore=.csv')
--> 208     return _retry_read_url(url, retry_count, pause, 'Yahoo!')
    209 
    210 

/usr/local/lib/python2.7/site-packages/pandas/io/data.pyc in _retry_read_url(url, retry_count, pause, name)
    175     #Get rid of unicode characters in index name.
    176     try:
--> 177         rs.index.name = rs.index.name.decode('unicode_escape').encode('ascii', 'ignore')
    178     except AttributeError:
    179         #Python 3 string has no decode method.

UnboundLocalError: local variable 'rs' referenced before assignment

把@JohnE的建议放在一起,下面的代码似乎可以做到这一点:

import pandas as pd

symbols_list = ['AAPL', 'TSLA', 'YHOO','GOOG', 'MSFT','ALTR','WDC','KLAC']

result = []
for ticker in symbols_list:
    url = 'http://chartapi.finance.yahoo.com/instrument/1.0/%s/chartdata;type=quote;range=1d/csv' % ticker.lower()
    data = pd.read_csv(url, skiprows=17)
    data.columns = ['timestamp', 'close', 'high', 'low', 'open', 'close']
    data['ticker'] = ticker
    result.append(data)

pd.concat(result)
结果如下所示:

      timestamp     close      high       low      open   close ticker
0    1429536719  125.5500  125.5700  125.4170  125.5100  183600   AAPL
1    1429536772  125.5900  125.6399  125.4600  125.5200  215000   AAPL
2    1429536835  125.7500  125.8000  125.5600  125.5901  348500   AAPL
...
367  1429559941   58.5700   58.5800   58.5400   58.5800  119100   KLAC
368  1429559946   58.5700   58.5700   58.5700   58.5700       0   KLAC
369  1429560000   58.5600   58.5600   58.5600   58.5600       0   KLAC

我想在前一天试试。你不会得到今天的数据,只有昨天,对吗?还请注意,根据文档或昨天,结束日期默认为“今天”?所以,无论如何,没有理由具体说明这一点。嗨,约翰,我正试图获取日内交易的数据。所以前一天的数据对我来说毫无用处。还有什么其他建议可以让我下载熊猫的实时数据吗?通过一点谷歌搜索,雅虎和谷歌似乎确实提供了免费的日内数据:我不认为有一种自动的方法可以将这些数据输入熊猫,尽管据我所知,datareader每天都会这样做。我想,如果这个功能存在的话,人们会对它感兴趣……你可能会想写一篇新的帖子,询问如何将当日报价输入熊猫。你现在的头衔不适合得到这样的答案。我确实发现这可能会有帮助:谢谢你,约翰。让我在quantshare.com上了解更多信息