使用pandas datareader提取数据时内置的keyerror

问题描述

我正在使用一个通过使用pandas datareader提取数据的循环,前两个循环工作正常。 但是从第三个循环开始,代码开始返回内置的keyerror,这是意外的。我想知道既然前两个循环工作正常,为什么从第三个循环开始返回错误?以及如何解决


import pandas as pd
import datetime as dt
import pandas_datareader as web
#====================================================
pd.set_option('display.max_columns',None)
pd.set_option('display.width',None)
pd.set_option('display.max_colwidth',-1)
#############
prev=15
endDate=dt.datetime.today().date()
sDate=endDate-pd.to_timedelta(prev,unit='d')
#############

def get_price(tickers): #input is a list or Series
    result=pd.DataFrame()
    for i in tickers:
        df=pd.DataFrame()
        
        df['Adj Close']=web.DataReader(i,'yahoo',sDate,endDate)['Adj Close']
        df['MA']=df['Adj Close'].rolling(5).mean()
        df.sort_values(ascending=False,inplace=True,by="Date")
        df['Higher?']=df['Adj Close']>df['MA']
        df['Higher?']=df['Higher?'].astype(int)
        
    
        result['{}'.format(i)]=df['Higher?']
        
    return result



#=============================================================================

base_url = "http://www.sectorspdr.com/sectorspdr/IDCO.Client.Spdrs.Holdings/Export/ExportExcel?symbol="

data = {                    
    'Ticker' :      [ 'XLC','XLY','XLP','XLE','XLF','XLV','XLI','XLB','XLRE','XLK','XLU' ],'Name' :    [ 'Communication Services','Consumer discretionary','Consumer Staples','Energy','Financials','Health Care','Industrials','Materials','Real Estate','Technology','Utilities' ]           
}                   

spdr_df = pd.DataFrame(data)     

print(spdr_df)




for i,row in spdr_df.iterrows():
    url =  base_url + row['Ticker']
    df_url = pd.read_excel(url)
    header = df_url.iloc[0]
    holdings_df = df_url[1:]
    holdings_df.set_axis(header,axis='columns',inplace=True)
    holdings_df=holdings_df['Symbol'].replace('.','-')
    
    
    a=get_price(holdings_df)
    print(a) 

以下列出了错误

    a=get_price(holdings_df)
  File "C:/Users/austi/Desktop/stock&Trading/get etf holdings Main Version.py",line 25,in <module>
    df['Adj Close']=web.DataReader(i,endDate)['Adj Close']
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\util\_decorators.py",line 214,in wrapper
    return func(*args,**kwargs)
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas_datareader\data.py",line 387,in DataReader
    session=session,File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas_datareader\base.py",line 251,in read
    df = self._read_one_data(self.url,params=self._get_params(self.symbols))
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas_datareader\yahoo\daily.py",line 165,in _read_one_data
    prices["Date"] = to_datetime(to_datetime(prices["Date"],unit="s").dt.date)
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\core\frame.py",line 2800,in __getitem__
    indexer = self.columns.get_loc(key)
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\core\indexes\base.py",line 2648,in get_loc
    return self._engine.get_loc(self._maybe_cast_indexer(key))
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\_libs\index.cp36-win32.pyd",line 111,in pandas._libs.index.IndexEngine.get_loc
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\_libs\index.cp36-win32.pyd",line 138,in pandas._libs.index.IndexEngine.get_loc
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\_libs\hashtable.cp36-win32.pyd",line 1619,in pandas._libs.hashtable.PyObjectHashTable.get_item
    Array of values of which unique will be calculated
  File "C:\Users\austi\Downloads\Python 3.6.3\Lib\site-packages\pandas\_libs\hashtable.cp36-win32.pyd",line 1627,in pandas._libs.hashtable.PyObjectHashTable.get_item
builtins.KeyError: 'Date'```   

解决方法

对于相同的行情自动收录器,没有日期列。

要捕获错误并继续,请尝试以下代码:

def get_price(tickers): #input is a list or Series
    result=pd.DataFrame()
    for i in tickers:
        try:
            df=pd.DataFrame()                
            df['Adj Close']=web.DataReader(i,'yahoo',sDate,endDate)['Adj Close']
            df['MA']=df['Adj Close'].rolling(5).mean()
            df.sort_values(ascending=False,inplace=True,by="Date")  # sometimes error
            df['Higher?']=df['Adj Close']>df['MA']
            df['Higher?']=df['Higher?'].astype(int)
            result['{}'.format(i)]=df['Higher?']
        except Exception as ex:  # no date column
            print('Ticker',i,'ERROR',ex)
            print(df)
        
    return result

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...