刘朝朋Aaron Liu 2020-03-02 00:11 采纳率: 0%
浏览 205
已采纳

多维度统计表作业-用python进行编程

地区 月份 人员 补贴 工作量
山东 2020年2月 张三 10 1
上海 2020年2月 李四 20 3
江苏 2020年2月 王五 30 6
浙江 2020年2月 马六 13 9
山东 2020年3月 刘七 5 1
江苏 2020年3月 赵八 30 3
上海 2020年3月 钱九 20 5
江苏 2020年3月 孙十 12 7

要求: 1 统计每个月每个地区的补贴数字

2 统计每个月每个人的工作量

要求用python进行统计,不用pandas模块,尽量减少重复代码

  • 写回答

2条回答 默认 最新

  • 青萍之默 2020-03-02 13:41
    关注
    data = {'地区':['山东','上海','江苏','浙江','山东','江苏','上海','江苏'],
            '月份':['2020年2月','2020年2月','2020年2月','2020年2月','2020年3月','2020年3月','2020年3月','2020年3月'],
            '人员':['张三','李四','王五','马六','刘七','王五','钱九','孙十'],
            '补贴':[10,20,30,13,5,30,20,12],
            '工作量':[1,3,6,9,1,3,5,7]
           }
    
    def sumInAtt(att,value,data=data):
        res = {}
        for i,d in enumerate(data['月份']):
            if d in res:
    #             continue
                if data[att][i] in res[d]:
    #                 continue
                    res[d][data[att][i]] += data[value][i]
                else:
                    res[d][data[att][i]] = data[value][i]
            else:
                res[d] = {data[att][i]:data[value][i]}
        return res
    
    #统计每个月每个地区的补贴数字
    sumInAtt('地区','工作量')
    # 1 统计每个月每个地区的补贴数字
    sumInAtt('人员','补贴')
    

    结果:
    图片说明

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题