python - 使用pandas的resample报错
问题描述
错误如下:
Traceback (most recent call last): File '<stdin>', line 1, in <module> File 'D:UsersAdministratorAnaconda2libsite-packagesspyderlibwidgetsexternalshellsitecustomize.py', line 699, in runfile execfile(filename, namespace) File 'D:UsersAdministratorAnaconda2libsite-packagesspyderlibwidgetsexternalshellsitecustomize.py', line 74, in execfile exec(compile(scripttext, filename, ’exec’), glob, loc) File 'C:/Users/Administrator/Documents/Python Scripts/untitled1.py', line 24, in <module> s3=s2.resample(’5min’, how=ohlc_dict, closed=’left’, label=’left’) File 'D:UsersAdministratorAnaconda2libsite-packagespandascoregeneric.py', line 4212, in resample base=base, key=on, level=level) File 'D:UsersAdministratorAnaconda2libsite-packagespandastseriesresample.py', line 944, in resample return tg._get_resampler(obj, kind=kind) File 'D:UsersAdministratorAnaconda2libsite-packagespandastseriesresample.py', line 1057, in _get_resampler 'but got an instance of %r' % type(ax).__name__)TypeError: Only valid with DatetimeIndex, TimedeltaIndex or PeriodIndex, but got an instance of ’Index’
我的代码如下:
names = [’date’, ’time’, ’open’, ’high’, ’low’, ’close’, ’vol’, ’amount’]s2=pd.read_csv(’E:/test/SZ399920.csv’,names=names, header=None, index_col=’date’)ohlc_dict = { ’open’:’first’,’high’:’max’, ’low’:’min’,’close’: ’last’,’vol’: ’sum’}s3=s2.resample(’5min’, how=ohlc_dict, closed=’left’, label=’left’)
dataframe文件的格式如下:
问题解答
回答1:你应该先把Index变成DatetimeIndex。你想resample到5分钟的话你也要把time放Index里:
df = pd.DataFrame({’date’: ['2008/07/01','2008/07/01','2008/07/01','2008/07/01','2008/07/01','2008/07/01','2008/07/01','2008/07/01'], ’time’: [’09:31’, ’09:32’,’09:33’,’09:34’,’09:35’,’09:36’,’09:37’, ’09:38’], ’vals’: [1, 2, 3, 4, 5, 6, 7, 8]})df2 = df.set_index(pd.DatetimeIndex(pd.to_datetime(df.date + ' ' + df.time)))df2.resample('5min', how={’vals’: ’mean’})
相关文章:
1. python - (初学者)代码运行不起来,求指导,谢谢!2. 为什么python中实例检查推荐使用isinstance而不是type?3. mysql里的大表用mycat做水平拆分,是不是要先手动分好,再配置mycat4. window下mysql中文乱码怎么解决??5. sass - gem install compass 使用淘宝 Ruby 安装失败,出现 4046. html5 - H5 SSE的本质是什么?7. javascript - h5上的手机号默认没有识别8. python - 获取到的数据生成新的mysql表9. python的文件读写问题?10. javascript - js 对中文进行MD5加密和python结果不一样。
