我有一个问题,我很肯定曾经运行过一些代码(在旧的Pandas版本上)。在0.9上,我得到了 * 没有数字类型聚合 * 错误。有什么想法吗?
In [31]: data
Out[31]:
<class 'pandas.core.frame.DataFrame'>
DatetimeIndex: 2557 entries, 2004-01-01 00:00:00 to 2010-12-31 00:00:00
Freq: <1 DateOffset>
Columns: 360 entries, -89.75 to 89.75
dtypes: object(360)
In [32]: latedges = linspace(-90., 90., 73)
In [33]: lats_new = linspace(-87.5, 87.5, 72)
In [34]: def _get_gridbox_label(x, bins, labels):
....: return labels[searchsorted(bins, x) - 1]
....:
In [35]: lat_bucket = lambda x: _get_gridbox_label(x, latedges, lats_new)
In [36]: data.T.groupby(lat_bucket).mean()
---------------------------------------------------------------------------
DataError Traceback (most recent call last)
<ipython-input-36-ed9c538ac526> in <module>()
----> 1 data.T.groupby(lat_bucket).mean()
/usr/lib/python2.7/site-packages/pandas/core/groupby.py in mean(self)
295 """
296 try:
--> 297 return self._cython_agg_general('mean')
298 except DataError:
299 raise
/usr/lib/python2.7/site-packages/pandas/core/groupby.py in _cython_agg_general(self, how, numeric_only)
1415
1416 def _cython_agg_general(self, how, numeric_only=True):
-> 1417 new_blocks = self._cython_agg_blocks(how, numeric_only=numeric_only)
1418 return self._wrap_agged_blocks(new_blocks)
1419
/usr/lib/python2.7/site-packages/pandas/core/groupby.py in _cython_agg_blocks(self, how, numeric_only)
1455
1456 if len(new_blocks) == 0:
-> 1457 raise DataError('No numeric types to aggregate')
1458
1459 return new_blocks
DataError: No numeric types to aggregate
5条答案
按热度按时间wnavrhmk1#
您是如何生成数据的?
查看输出如何显示您的数据是'object'类型?groupby操作专门检查每列是否首先是数值数据类型。
看↑
你是否先初始化一个空的DataFrame,然后填充它?如果是这样,这可能就是为什么它在新版本中发生了变化,因为在0.9之前,空的DataFrame被初始化为float类型,但现在它们是对象类型。如果是这样,你可以将初始化更改为
DataFrame(dtype=float)
。也可以调用
frame.astype(float)
bvjxkvbb2#
我得到这个错误生成一个由时间戳和数据组成的 Dataframe :
添加建议的解决方案对我很有效:
谢谢常舍!
示例:
rvpgvaaj3#
我通过以下方式完成:
zbdgwd5y4#
这里也遇到了同样的问题,搜索了这么久才意识到我的值不是浮点数而是字符串。
以下是解决我的问题的方法:
k10s72fa5#
当我在一个
int/object
数据类型的列上从groupby
调用mean()
方法时,遇到了这个错误。解决方法是将该列转换为float
,如下所示: