如何使用 Pandas 的 applymap 函数一次性指定数据表输出格式?
如何一次性指定 pandas 数据表输出格式
在分析数据时,对数据表进行格式化输出非常重要,以便更清晰地呈现信息。尤其是当数据类型混合时,例如字符串、整数和浮点数,需要针对每种类型应用特定的格式。
pandas 提供了灵活的方式来设置数据表的输出格式。除了分别对各列进行格式化之外,还可以采用以下方法一次性对不同类型的数据应用统一的格式:
使用 applymap
applymap 函数允许对数据表中的每个元素应用指定的函数。下面是指定不同类型数据的格式的代码:
dt = dt.applymap(lambda x: format(x, ".2%") if pd.api.types.is_float(x) else '{:.1f}万'.format(x/10000) if pd.api.types.is_integer(x) else x)
这段代码使用了 lambda 函数:如果元素是浮点数,则格式化为小数点后两位的百分数;如果是整数,则转换为以万为单位的字符串,保留一位小数;否则,保持元素不变。
执行代码后,数据表 dt 的输出将如下所示:
产品 任务 销售 完成率0 A 10万 5万 0.50%1 B 20万 30万 1.50%2 C 30万 10万 0.33%
总结
applymap 函数提供了对 pandas 数据表中的不同元素应用一致格式的强大方法。这样不仅可以节省时间,还可以确保清晰一致的输出。