我有以下数据框:
key1 key2
0 a one
1 a two
2 b one
3 b two
4 a one
5 c two
现在,我想通过key1对数据帧进行分组,并使用值1计算列key2以获得此结果:
key1
0 a 2
1 b 1
2 c 0
我只是得到了通常的计数:
df.groupby(['key1']).size()
但我不知道如何插入条件。
我尝试过这样的事情:
df.groupby(['key1']).apply(df[df['key2'] == 'one'])
但我不会得到进一步的
如果我在这里得到一些帮助会很棒
问候
答案 0 :(得分:13)
我认为你需要先添加条件:
#if need also category c with no values of 'one'
df11=df.groupby('key1')['key2'].apply(lambda x: (x=='one').sum()).reset_index(name='count')
print (df11)
key1 count
0 a 2
1 b 1
2 c 0
或者将categorical
与key1
一起使用,然后size
添加缺失值:
df['key1'] = df['key1'].astype('category')
df1 = df[df['key2'] == 'one'].groupby(['key1']).size().reset_index(name='count')
print (df1)
key1 count
0 a 2
1 b 1
2 c 0
如果需要所有组合:
df2 = df.groupby(['key1', 'key2']).size().reset_index(name='count')
print (df2)
key1 key2 count
0 a one 2
1 a two 1
2 b one 1
3 b two 1
4 c two 1
df3 = df.groupby(['key1', 'key2']).size().unstack(fill_value=0)
print (df3)
key2 one two
key1
a 2 1
b 1 1
c 0 1
答案 1 :(得分:3)
您可以计算“一个人”的出现次数。对于groupby数据帧,在列' key2'像这样:
df.groupby('key1')['key2'].apply(lambda x: x[x == 'one'].count())
产量
key1
a 2
b 1
c 0
Name: key2, dtype: int64
答案 2 :(得分:1)
选项1
df.set_index('key1').key2.eq('one').sum(level=0).astype(int).reset_index()
key1 key2
0 a 2
1 b 1
2 c 0
选项2
df.key2.eq('one').groupby(df.key1).sum().astype(int).reset_index()
key1 key2
0 a 2
1 b 1
2 c 0
选项3
f, u = df.key1.factorize()
pd.DataFrame(dict(key1=u, key2=np.bincount(f, df.key2.eq('one')).astype(int)))
key1 key2
0 a 2
1 b 1
2 c 0
选项4
pd.crosstab(df.key1, df.key2.eq('one'))[True].rename('key2').reset_index()
key1 key2
0 a 2
1 b 1
2 c 0
选项5
pd.get_dummies(df.key1).mul(
df.key2.eq('one'), 0
).sum().rename_axis('key1').reset_index(name='key2')
key1 key2
0 a 2
1 b 1
2 c 0
答案 3 :(得分:0)
您可以通过在key和unstack()上应用groupby()来做到这一点。
if userName.contains("step") && userName.lowercased() == searchName {
print("We have found the user")
}
答案 4 :(得分:0)
也许不是最快的解决方案,但是如果key2等于“ one”,则可以用一列新数据框来创建数据框。
df2 = df.assign(oneCount =
lambda x: [1 if row.key2 == 'one' else 0 for index, row in x.iterrows()])
key1 key2 oneCount
0 a one 1
1 a two 0
2 b one 1
3 b two 0
4 a one 1
5 c two 0
然后将其汇总。
df3 = df2.groupby('key1').agg({"oneCount":sum}).reset_index()
key1 oneCount
0 a 2
1 b 1
2 c 0
答案 5 :(得分:0)
我需要计算2列(带有两个参数的lambda)作为示例:
groupby数据帧,在“ key2”列中像这样:df.groupby('key1')['key2']。apply(lambda x:x [x =='one']。count())>