- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个 Pandas 数据框
datetime machineID errorID
0 2015-01-06 03:00:00 1 error3
1 2015-02-03 06:00:00 1 error4
2 2015-02-21 11:00:00 1 error1
3 2015-02-21 16:00:00 1 error2
4 2015-03-20 06:00:00 1 error1
5 2015-04-04 06:00:00 1 error5
6 2015-05-04 06:00:00 1 error4
7 2015-05-19 06:00:00 1 error2
8 2015-05-19 06:00:00 1 error3
9 2015-06-03 06:00:00 1 error5
现在我想拆开 errorID,这样我就可以获取基于 error1
、error2
...error5
的列。为此,我在 Pandas 中使用了 groupby 和 unstack 方法
a = errors.groupby(['machineID', 'datetime', 'errorID']).size().unstack('errorID', fill_value=0)
这给了我这个数据框
errorID error1 error2 error3 error4 error5
machineID datetime
1 2015-01-06 03:00:00 0 0 1 0 0
2015-02-03 06:00:00 0 0 0 1 0
2015-02-21 11:00:00 1 0 0 0 0
2015-02-21 16:00:00 0 1 0 0 0
2015-03-20 06:00:00 1 0 0 0 0
现在我想根据 24H
频率和 datetime
对这些数据重新采样。但是当我使用 resample
函数时,它给我错误 KeyError: 'The grouper name datetime is not found'
a.resample('24H', on='datetime').agg({'error1':'mean','error2':'mean','error3':'mean','error4':'mean', 'error5':'mean'}).rename(columns={'error1':'error1_mean','error2' : 'error2_mean', 'error3': 'error3_mean', 'error4': 'error4_24mean','error5': 'error5_24mean'})
当我列出此数据框中的所有列时,它仅显示 ['error1', 'error2', 'error3', 'error4', 'error5']
这是整个错误
---------------------------------------------------------------------------
KeyError Traceback (most recent call last)
<ipython-input-127-607c418305a0> in <module>
----> 1 a.resample('24H', on='datetime').agg({'error1':'mean','error2':'mean','error3':'mean','error4':'mean', 'error5':'mean'}).rename(columns={'error1':'error1_mean','error2' : 'error2_mean', 'error3': 'error3_mean', 'error4': 'error4_24mean','error5': 'error5_24mean'})
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/pandas/core/generic.py in resample(self, rule, how, axis, fill_method, closed, label, convention, kind, loffset, limit, base, on, level)
8447 base=base,
8448 key=on,
-> 8449 level=level,
8450 )
8451 return _maybe_process_deprecations(
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/pandas/core/resample.py in resample(obj, kind, **kwds)
1304 """
1305 tg = TimeGrouper(**kwds)
-> 1306 return tg._get_resampler(obj, kind=kind)
1307
1308
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/pandas/core/resample.py in _get_resampler(self, obj, kind)
1428
1429 """
-> 1430 self._set_grouper(obj)
1431
1432 ax = self.ax
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/pandas/core/groupby/grouper.py in _set_grouper(self, obj, sort)
171 else:
172 if key not in obj._info_axis:
--> 173 raise KeyError("The grouper name {0} is not found".format(key))
174 ax = Index(obj[key], name=key)
175
KeyError: 'The grouper name datetime is not found'
我不知道如何在 groupby 之后使用重采样
最佳答案
首先将值转换为日期时间:
errors['datetime'] = pd.to_datetime(errors['datetime'])
a = errors.groupby(['machineID', 'datetime', 'errorID']).size().unstack('errorID', fill_value=0)
然后如果需要对每个 machineID
resample
使用:
a = a.reset_index(level=0).groupby('machineID').resample('24H').agg({'error1':'mean','error2':'mean','error3':'mean','error4':'mean', 'error5':'mean'}).rename(columns={'error1':'error1_mean','error2' : 'error2_mean', 'error3': 'error3_mean', 'error4': 'error4_24mean','error5': 'error5_24mean'})
或者如果只需要resample
使用:
a = a.reset_index(level=0).resample('24H').agg({'error1':'mean','error2':'mean','error3':'mean','error4':'mean', 'error5':'mean'}).rename(columns={'error1':'error1_mean','error2' : 'error2_mean', 'error3': 'error3_mean', 'error4': 'error4_24mean','error5': 'error5_24mean'})
或者如果需要 groupby 和 Grouper
使用:
a = a.groupby(['machineID', pd.Grouper(freq='24H', level='datetime')]).agg({'error1':'mean','error2':'mean','error3':'mean','error4':'mean', 'error5':'mean'}).rename(columns={'error1':'error1_mean','error2' : 'error2_mean', 'error3': 'error3_mean', 'error4': 'error4_24mean','error5': 'error5_24mean'})
关于python - groupby 后找不到 Grouper 名称 `datetime`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70346473/
例如,我有一个父类Author: class Author { String name static hasMany = [ fiction: Book,
代码如下: dojo.query(subNav.navClass).forEach(function(node, index, arr){ if(dojo.style(node, 'd
我有一个带有 Id 和姓名的学生表和一个带有 Id 和 friend Id 的 Friends 表。我想加入这两个表并找到学生的 friend 。 例如,Ashley 的 friend 是 Saman
我通过互联网浏览,但仍未找到问题的答案。应该很容易: class Parent { String name Child child } 当我有一个 child 对象时,如何获得它的 paren
我正在尝试创建一个以 Firebase 作为我的后端的社交应用。现在我正面临如何(在哪里?)找到 friend 功能的问题。 我有每个用户的邮件地址。 我可以访问用户的电话也预订。 在传统的后端中,我
我主要想澄清以下几点: 1。有人告诉我,在 iOS 5 及以下版本中,如果您使用 Game Center 设置多人游戏,则“查找 Facebook 好友”(如与好友争夺战)的功能不是内置的,因此您需要
关于redis docker镜像ENTRYPOINT脚本 docker-entrypoint.sh : #!/bin/sh set -e # first arg is `-f` or `--some-
我是一名优秀的程序员,十分优秀!