pandas 类型错误:不可散列的类型:“切片”

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/44078930/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-09-14 03:38:37  来源:igfitidea点击:

TypeError: unhashable type: 'slice'

pythonpandas

提问by Stacey

I am trying to run a regression using the following dataframe dfMyRollthe head of the dataframe looks like:

我正在尝试使用以下数据框运行回归,数据框dfMyRoll的头部如下所示:

                SCORE  SCORE_LAG
date                           
2007-10-29 -0.031551        NaN
2007-10-30  0.000100  -0.031551
2007-10-31  0.000100   0.000100
2007-11-01  0.000100   0.000100
2007-11-02  0.000100   0.000100 

The code that I am using is :

我使用的代码是:

import glob
import pandas as pd 
import os.path
import scipy
from scipy.stats import linregress

def main():

    dataPath = "C:/Users/Stacey/Documents/data/Roll"
    roll = 4
    1ID = "BBG.XNGS.AAPL.S"
    2ID = "BBG.XNGS.AMAT.S"
    print(1ID,1ID)
    cointergration = getCointergration(dataPath,1ID,2ID,roll)

    return

def getCointergration(dataPath,1ID,2ID,roll):

    for myRoll in range((roll-4),roll,1):
        path = dataPath+str(myRoll)+'/'
        filename='PairData_'+1ID+'_'+2ID+'.csv'

        for fname in glob.iglob(path+filename):

            dfMyRoll = pd.read_csv(fname, header=0, usecols=[0,31],parse_dates=[0], dayfirst=True,index_col=[0], names=['date', 'SCORE'])
            dfMyRoll['SCORE_LAG'] = dfMyRoll['SCORE'].shift(1)
            print('cointergration',dfMyRoll.head())

            X = dfMyRoll[1:,'SCORE']

            Y = dfMyRoll[1:,'SCORE_LAG']
          slope,intercept,_,_,stderr=linregress(dfMyRoll[1:,'SCORE'],dfMyRoll[1:,'SCORE_LAG'])

if __name__ == "__main__":

    print ("CointergrationTest...19/05/17")

    try:

        main()

    except KeyboardInterrupt:

        print ("Ctrl+C pressed. Stopping...")  

I get the error: TypeError: unhashable type: 'slice'. I have looked at previous posts on this subject and tried adding iloc to the X and Y time series in the follwing way:

我收到错误:TypeError: unhashable type: 'slice'。我查看了有关此主题的以前的帖子,并尝试以以下方式将 iloc 添加到 X 和 Y 时间序列:

        X = dfMyRoll.iloc[1:,'SCORE']

        Y = dfMyRoll.iloc[1:,'SCORE_LAG']

but unfortunatly I can't seem to find a solution. Please see below for a stack trace:

但不幸的是,我似乎无法找到解决方案。请参阅下面的堆栈跟踪:

Traceback (most recent call last):

  File "<ipython-input-3-431422978139>", line 1, in <module>
    runfile('C:/Users/Stacey/Documents/scripts/cointergrationTest.py', wdir='C:/Users/Stacey/Documents/scripts')

  File "C:\Anaconda\lib\site-packages\spyder\utils\site\sitecustomize.py", line 866, in runfile
    execfile(filename, namespace)

  File "C:\Anaconda\lib\site-packages\spyder\utils\site\sitecustomize.py", line 102, in execfile
    exec(compile(f.read(), filename, 'exec'), namespace)

  File "C:/Users/Stacey/Documents/scripts/cointergrationTest.py", line 64, in <module>
    main()

  File "C:/Users/Stacey/Documents/scripts/cointergrationTest.py", line 23, in main
    cointergration = getCointergration(dataPath,1ID,2ID,roll)

  File "C:/Users/Stacey/Documents/scripts/cointergrationTest.py", line 42, in getCointergration
    X = dfMyRoll[1:,'SCORE']

  File "C:\Anaconda\lib\site-packages\pandas\core\frame.py", line 2059, in __getitem__
    return self._getitem_column(key)

  File "C:\Anaconda\lib\site-packages\pandas\core\frame.py", line 2066, in _getitem_column
    return self._get_item_cache(key)

  File "C:\Anaconda\lib\site-packages\pandas\core\generic.py", line 1384, in _get_item_cache
    res = cache.get(item)

TypeError: unhashable type: 'slice'

Any assistance would be much appreciated

任何帮助将不胜感激

Thanks

谢谢

回答by Andy Hayden

You need to use loc rather than iloc:

您需要使用 loc 而不是 iloc:

X = dfMyRoll.loc[1:,'SCORE']

Y = dfMyRoll.loc[1:,'SCORE_LAG']

iloc is read as "integer location", and only accepts integer position. loc is somewhat more forgiving and allows both (you can also use ix).

iloc 被读作“整数位置”,并且只接受整数位置。loc 更宽容一些,并允许两者(你也可以使用ix)。