时间:2021-05-22
groupby的函数定义:
DataFrame.groupby(by=None, axis=0, level=None, as_index=True, sort=True, group_keys=True, squeeze=False, **kwargs)
其他的参数解释就看文档吧:链接:pandas.DataFrame.groupby 介绍文档
所见 1 :日常用法
import pandas as pddf = pd.DataFrame({'Gender' : ['男', '女', '男', '男', '男', '男', '女', '女', '女'], 'name' : ['周杰伦', '蔡依林', '林俊杰', '周杰伦', '林俊杰', '周杰伦', '田馥甄', '蔡依林', '田馥甄'], 'income' : [4.5, 2.9, 3.8, 3.7, 4.0, 4.1, 1.9, 4.1, 3.2], 'expenditure' : [1.5, 1.9, 2.8, 1.7, 4.1, 2.5, 1.1, 3.4, 1.2] })#根据其中一列分组df_expenditure_mean = df.groupby(['Gender']).mean()#根据其中两列分组df_expenditure_mean = df.groupby(['Gender', 'name']).mean()#只对其中一列求均值df_expenditure_mean = df.groupby(['Gender', 'name'])['income'].mean()输出示例:
所见 2 :解决groupby.sum() 后层级索引levels上移的问题
上图中的输出二,虽然是 DataFrame 的格式,但是若需要与其他表匹配的时候,这个格式就有些麻烦了。匹配数据时,我们需要的数据格式是:列名都在第一行,数据行中也不能有Gender 列这样的合并单元格。因此,我们需要做一些调整,将 as_index 改为False ,默认是Ture 。
#不以组标签为索引,通过 as_index 来实现df_expenditure_mean = df.groupby(['Gender', 'name'], as_index=False).mean()输出:
所见 3 :解决groupby.apply() 后层级索引levels上移的问题
在所见 2 中我们知道,使用参数 as_index 就可使 groupby 的结果不以组标签为索引,但是后来在使用groupby.apply() 时发现,as_index 参数失去了效果。如下例所示:
# 使用了 as_index=False,但是从输出结果中可见没起到作用df_apply = df.groupby(['Gender', 'name'], as_index=False).apply(lambda x: sum(x['income']-x['expenditure'])/sum(x['income']))df_apply = pd.DataFrame(df_apply,columns=['存钱占比'])#转化成dataframe格式输出:
解决办法:加一句df_apply_index = df_apply.reset_index()
# 加一句df_apply_index = df_apply.reset_index()df_apply = df.groupby(['Gender', 'name'], as_index=False).apply(lambda x: sum(x['income']-x['expenditure'])/sum(x['income']))df_apply = pd.DataFrame(df_apply,columns=['存钱占比'])#转化成dataframe格式df_apply_index = df_apply.reset_index()输出:
所见 4 :groupby函数的分组结果保存成DataFrame
所见 1 中的输出三,明显是 Series ,我们需要将其转化为 DataFrame 格式的数据。
#只对其中一列求均值,并转化为 DataFramedf_expenditure_mean = df.groupby(['Gender', 'name'], as_index=False)['income'].mean()df_expenditure_mean = pd.DataFrame(df_expenditure_mean)#转化成dataframe格式df_expenditure_mean.rename(columns={'income':'收入均值'}, inplace = True)输出:
到此这篇关于 DataFrame.groupby() 所见的各种用法详解的文章就介绍到这了,更多相关 DataFrame.groupby()用法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
今天用实例总结一下groupby的用法。归纳一下:groupby:ALL,Cube,RollUP,Compute,Computeby创建数据脚本CreateTa
Django框架models使用groupby详解:首先,看下列代码:UserData.objects.filter(hubid=sensorid,time__
1.having子句的用法 having子句对groupby子句所确定的行组进行控制,having子句条件中只允许涉及常量,聚组函数或groupby子句中
Oracle中groupby用法在select语句中可以使用groupby子句将行划分成较小的组,一旦使用分组后select操作的对象变为各个分组后的数据,使用
1.摘要dropna()方法,能够找到DataFrame类型数据的空值(缺失值),将空值所在的行/列删除后,将新的DataFrame作为返回值返回。2.函数详解