使用pandas GroupBy检查组中的所有元素是否相等 [英] Check if all elements in a group are equal using pandas GroupBy
本文介绍了使用pandas GroupBy检查组中的所有元素是否相等的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
有没有一种pythonic方法可以按字段分组并检查每个结果组的所有元素是否具有相同的值?
Is there a pythonic way to group by a field and check if all elements of each resulting group have the same value?
样本数据:
datetime rating signal
0 2018-12-27 11:33:00 IG 0
1 2018-12-27 11:33:00 HY -1
2 2018-12-27 11:49:00 IG 0
3 2018-12-27 11:49:00 HY -1
4 2018-12-27 12:00:00 IG 0
5 2018-12-27 12:00:00 HY -1
6 2018-12-27 12:49:00 IG 0
7 2018-12-27 12:49:00 HY -1
8 2018-12-27 14:56:00 IG 0
9 2018-12-27 14:56:00 HY -1
10 2018-12-27 15:12:00 IG 0
11 2018-12-27 15:12:00 HY -1
12 2018-12-20 15:14:00 IG 0
13 2018-12-20 15:14:00 HY -1
14 2018-12-20 15:50:00 IG -1
15 2018-12-20 15:50:00 HY -1
16 2018-12-27 13:26:00 IG 0
17 2018-12-27 13:26:00 HY -1
18 2018-12-27 13:44:00 IG 0
19 2018-12-27 13:44:00 HY -1
20 2018-12-27 15:06:00 IG 0
21 2018-12-27 15:06:00 HY -1
22 2018-12-20 15:48:00 IG 0
23 2018-12-20 15:48:00 HY -1
分组部分可以通过
df.groupby([datetime.dt.date,'rating'])
但是,如果来自signal
的所有值都相同,我肯定必须有一种简单的方法来利用石斑鱼并使用transform语句返回1.
However, I'm sure there must be a simple way to leverage the grouper and use a transform statement to return 1 if all the values from signal
are the same.
所需的输出
2018-12-20 HY True
IG False
2018-12-27 HY True
IG True
推荐答案
使用groupby
和nunique
,并检查结果是否为1:
Use groupby
and nunique
, and check whether the result is 1:
df.groupby([df.datetime.dt.date, 'rating']).signal.nunique().eq(1)
datetime rating
2018-12-20 HY True
IG False
2018-12-27 HY True
IG True
Name: signal, dtype: bool
或者类似地,将apply
与set
转换一起使用:
Or, similarly, using apply
with set
conversion:
(df.groupby([df.datetime.dt.date, 'rating']).signal
.apply(lambda x: len(set(x)) == 1))
datetime rating
2018-12-20 HY True
IG False
2018-12-27 HY True
IG True
Name: signal, dtype: bool
PS.,您无需分配临时列,groupby
带有任意石斑鱼参数.
PS., you don't need to assign a temp column, groupby
takes arbitrary grouper arguments.
这篇关于使用pandas GroupBy检查组中的所有元素是否相等的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文