前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pandas统计:最低分,最高分,总人数,分数段人数与百分率

pandas统计:最低分,最高分,总人数,分数段人数与百分率

作者头像
哆哆Excel
发布2022-10-25 15:17:33
9430
发布2022-10-25 15:17:33
举报
文章被收录于专栏:哆哆Excel

pandas统计:最低分,最高分,总人数,分数段人数与百分率

成绩表如下:

代码如下:

代码语言:javascript
复制
'''
本程序用于统计:最低分,最高分,总人数,分数段人数与百分率
'''
import pandas as pd
#统计60-79人数
def d60to79(arr):
    return sum((arr >= 60) & (arr<80))
#统计60-79人数百分率
def d60to79f(arr):
    return sum((arr >= 60) & (arr<80))/len(arr)
#统计80-100人数
def d80to100(arr):
    return sum( (arr>= 80) & (arr<=100))
#统计8-100人数百分率
def d80to100f(arr):
    return sum( (arr>= 80) & (arr<=100))/len(arr)
path="D://yhd_python_home/yhd-pandas-groupby-count/stu10.xlsx"
path_out="D://yhd_python_home/yhd-pandas-groupby-count/stu_count.xlsx"
#读取一个excel文件中的两个表提数据,以序号为index,身份证定为str类型
df=pd.read_excel(path)
dfg=df.groupby('单位')
for name,group in dfg:
    print(name)
    print(group)
    #d[name]=group
print(dfg.apply(lambda x:x[['语文','数学']].agg({d60to80,d80to100,'count','max','min'})))
y2=dfg[['语文','数学']].agg({d60to79,d60to79f,d80to100,d80to100f,'count','max','min'}).round(2)
print(y2)
y2.to_excel(path_out)

说明

  1. 程序先读取excel文件数据,
  2. 再用groupby进行分组
  3. 再用自定义的函数进行统计
  4. 再输出为excel文件
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 哆哆Excel 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档