解决pandas 四舍五入异常问题

import pandas as pd
import decimal

def count_employees(employees: pd.DataFrame) -> pd.DataFrame:
    D = decimal.Decimal
    decimal.getcontext().rounding = "ROUND_HALF_UP" # 设置舍入方式为四舍五入

    emp_table = employees[~employees["reports_to"].isnull()]

    re_table = employees[["employee_id","name"]].merge(emp_table[["reports_to","age"]],left_on="employee_id",right_on="reports_to",how="left")

    re_table = re_table.dropna(subset=["reports_to"])

    return re_table.groupby(["employee_id","name"]).agg(
        reports_count=("reports_to","count"),
        average_age = ("age",lambda x:D(x.mean()).quantize(D("0")))).reset_index() # 对应pandas四舍五入问题,主要看这个
    

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值