[Python办公]Pandas创建透视表入门

[Python办公]Pandas创建透视表入门

Pandas 的 pivot_table 是一个用于数据透视的强大工具,它允许你根据一个或多个键对数据进行分组,然后对每个组进行聚合计算。透视表是一种数据汇总工具,常用于数据分析、报告生成和探索性数据分析。

基本用法

pivot_table 的基本用法包括以下几个参数:

  1. data: 要进行分析的 DataFrame,即要透视的数据。
  2. values: 要聚合的列名或列名列表(即多个列名)。
  3. index: 行索引的列名或列名列表。
  4. columns: 列索引的列名或列名列表。
  5. aggfunc: 聚合函数,可以是预定义的函数名(如 ‘mean’, ‘sum’, ‘count’ 等),也可以是自定义的函数。

示例

假设我们有一个 DataFrame df,其中包含员工的信息,包括部门、职位和薪资。我们想要创建一个透视表,按部门和职位对薪资进行求和。

import pandas as pd

# 创建一个示例 DataFrame
data = {
    '部门': ['A', 'A', 'B', 'B'],
    '职位': ['经理', '开发', '经理', '开发'],
    '薪资': [500, 600, 700, 800],
    '性别': ['男', '女', '男', '女']
}
# 将数据转化为pandas的dataframe
df = pd.DataFrame(data)

pivot_table = pd.pivot_table(
    df,
    values='薪资',
    index='部门',
    columns='职位',
    aggfunc='sum'
)
print(f'原始df;\n{df}')
print(f'透视结果;\n{pivot_table}')

这将创建一个透视表,其中行索引是部门,列索引是职位,每个单元格的值是对应部门和职位的薪资总和。

运行结果:

高级用法

pivot_table 还支持更多高级功能,例如:

  • margins: 设置为 True 时,会在透视表的底部和右侧添加总计行和列。
  • fill_value: 用于替换 NaN 值的值。
  • dropna: 设置为 False 时,即使某些组合没有数据,也会在透视表中保留对应的行和列。

注意事项

  • 当 index 和 columns 中有多个列时,透视表将根据这些列的组合进行数据分组。
  • 如果 values 是一个列表,透视表将为每个指定的列分别计算聚合值。
  • aggfunc 可以是单个函数,也可以是函数的字典,用于对不同列应用不同的聚合函数。

 

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pandas中,数据透视是一种可以对数据动态排布并且分类汇总的格格式,通过使用`pandas.pivot_table()`函数或`pandas.DataFrame.pivot_table()`函数来创建透视透视可以对数据进行各种计算操作,如求和、计数等,并根据不同的布局方式重新排列行号、列标和页字段。每次改变布局后,透视会重新计算数据。在使用Excel进行数据分析时,透视是非常常用的功能,Pandas提供了透视功能来满足类似的需求。 `pandas.pivot_table()`函数的主要参数有: - `data`: 数据源,即一个DataFrame对象 - `index`: 行索引,传入原始数据的列名 - `columns`: 列索引,传入原始数据的列名 - `values`: 要进行聚合操作的列名 - `aggfunc`: 聚合函数,用于对数据进行计算 而`pandas.DataFrame.pivot_table()`函数与`pandas.pivot_table()`函数相似,只是没有`data`参数,因为它是作为DataFrame对象的一个方法来使用的。 通过使用这些函数,我们可以创建数据透视来对数据进行分析和汇总。123 #### 引用[.reference_title] - *1* [python入门——Pandas透视(pivot_table)](https://blog.csdn.net/weixin_49249463/article/details/127578300)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* *3* [pandas 数据透视](https://blog.csdn.net/ljh18885466426/article/details/120048268)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值