首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据条件在熊猫数据帧中计算值发生的次数。

根据条件在熊猫数据帧中计算值发生的次数。
EN

Stack Overflow用户
提问于 2021-05-18 13:58:42
回答 2查看 642关注 0票数 2

我试图计算一个值在数据帧中的特定位置上发生了多少次。

举个例子,我使用了这个数据框架:

代码语言:javascript
复制
   import pandas as pd
   
   d = {'Fruit': ['Apple', 'Apple', 'Apple', 'Onion', 'Onion', 'Onion', 'Onion', 'Pear', 'Pear', 'Pear', 
   'Pear', 'Pear'],
        'Country': ['USA', 'SUI', 'USA', 'SUI', 'USA', 'SUI', 'SUI', 'USA', 'USA', 'USA', 'SUI', 'SUI']}

   df = pd.DataFrame(data=d)

我不明白如何计算,例如,在美国和SUI中有多少个苹果,并将其添加到“计数”列中。

输出应该如下所示:

代码语言:javascript
复制
import pandas as pd

d = {'Fruit': ['Apple', 'Apple', 'Apple', 'Onion', 'Onion', 'Onion', 'Onion', 'Pear', 'Pear', 'Pear', 'Pear', 'Pear'],
     'Country': ['USA', 'SUI', 'USA', 'SUI', 'USA', 'SUI', 'SUI', 'USA', 'USA', 'USA', 'SUI', 'SUI'],
     'Count': [2, 1, 2, 3, 1, 3, 3, 3, 3, 3, 2, 2]}

df = pd.DataFrame(data=d)

我知道如何计算值本身(果树列中有多少苹果),但不知道如何将此条件添加到计算中。

谢谢你提前帮忙。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-05-18 14:06:11

试试群比变换

代码语言:javascript
复制
df['counts'] = df.groupby(['Fruit', 'Country'])['Country'].transform('size')

df

代码语言:javascript
复制
    Fruit Country  counts
0   Apple     USA       2
1   Apple     SUI       1
2   Apple     USA       2
3   Onion     SUI       3
4   Onion     USA       1
5   Onion     SUI       3
6   Onion     SUI       3
7    Pear     USA       3
8    Pear     USA       3
9    Pear     USA       3
10   Pear     SUI       2
11   Pear     SUI       2
票数 3
EN

Stack Overflow用户

发布于 2021-05-18 14:04:38

您可以使用groupby后跟一个join,如下所示:

代码语言:javascript
复制
fruit_counts = df.groupby(["Fruit", "Country"]).size().rename("Count")
df.join(fruit_counts, on=["Fruit", "Country"])

输出:

代码语言:javascript
复制
    Fruit Country  Count
0   Apple     USA      2
1   Apple     SUI      1
2   Apple     USA      2
3   Onion     SUI      3
4   Onion     USA      1
5   Onion     SUI      3
6   Onion     SUI      3
7    Pear     USA      3
8    Pear     USA      3
9    Pear     USA      3
10   Pear     SUI      2
11   Pear     SUI      2
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67587760

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档