使用Pandas实现Excel中的数据透视表的项目实践

 更新时间:2025年05月02日 11:18:49   作者:Bruce_xiaowei  
数据透视表是一种非常强大的工具,它可以帮助我们快速汇总、分析和可视化大量数据,本文主要介绍了使用Pandas实现Excel中的数据透视表的项目实践,感兴趣的可以了解一下

引言

在数据分析中,数据透视表是一种非常强大的工具,它可以帮助我们快速汇总、分析和可视化大量数据。虽然Excel提供了内置的数据透视表功能,但对于需要进行更复杂操作或自动化处理的场景,Python中的Pandas库提供了一个灵活且强大的替代方案。本文将通过具体的示例,展示如何使用Pandas实现类似Excel中的数据透视表功能。

准备工作

首先确保你的环境中已经安装了Pandas库。如果尚未安装,可以通过pip命令快速安装:

pip install pandas openpyxl

接下来,我们将创建一个模拟的真实销售数据表格文件 sales_data.xlsx,并使用Pandas读取该文件,然后生成数据透视表。

创建模拟销售数据

假设我们的 sales_data.xlsx 文件包含以下数据:

日期产品名称销售额地区销售员
2021-01-01产品A8000华东张三
2021-01-02产品B12000华北李四
2021-01-03产品C5000华南王五
2021-01-04产品D15000华东张三
2021-01-05产品E7000华中李四
2021-01-06产品F20000华北王五
2021-01-07产品G9000华东张三
2021-01-08产品H3000华南李四
2021-01-09产品I6000华中王五
2021-01-10产品J11000华东张三

代码实现及输出

首先,我们需要创建这个模拟数据并保存到Excel文件中,然后使用Pandas读取并生成数据透视表。

import pandas as pd

# 创建模拟数据
data = {
    '日期': ['2021-01-01', '2021-01-02', '2021-01-03', '2021-01-04', '2021-01-05',
            '2021-01-06', '2021-01-07', '2021-01-08', '2021-01-09', '2021-01-10'],
    '产品名称': ['产品A', '产品B', '产品C', '产品D', '产品E', '产品F', '产品G', '产品H', '产品I', '产品J'],
    '销售额': [8000, 12000, 5000, 15000, 7000, 20000, 9000, 3000, 6000, 11000],
    '地区': ['华东', '华北', '华南', '华东', '华中', '华北', '华东', '华南', '华中', '华东'],
    '销售员': ['张三', '李四', '王五', '张三', '李四', '王五', '张三', '李四', '王五', '张三']
}

# 将数据保存到Excel文件
df = pd.DataFrame(data)
df.to_excel('sales_data.xlsx', index=False)

# 重新加载数据
df = pd.read_excel('sales_data.xlsx')

# 显示前几行以检查数据
print("原始数据:")
print(df.head())

运行上述代码后,你将看到如下输出结果:

原始数据

        日期  产品名称  销售额   地区  销售员
0  2021-01-01    产品A   8000   华东    张三
1  2021-01-02    产品B  12000   华北    李四
2  2021-01-03    产品C   5000   华南    王五
3  2021-01-04    产品D  15000   华东    张三
4  2021-01-05    产品E   7000   华中    李四

示例1: 按地区和销售员汇总销售额

假设我们想要按地区和销售员汇总销售额,并计算每个组合的总销售额。

# 生成数据透视表
pivot_table1 = pd.pivot_table(df, values='销售额', index=['地区', '销售员'], aggfunc='sum')

print("\n按地区和销售员汇总销售额:")
print(pivot_table1)

按地区和销售员汇总销售额:

地区  销售员
华东  张三     33000
华北  李四     12000
      王五     20000
华南  王五      8000
华中  李四     13000
      王五      6000
Name: 销售额, dtype: int64

示例2: 按地区汇总销售额,并显示每个地区的总销售额

假设我们想要按地区汇总销售额,并显示每个地区的总销售额。

# 生成数据透视表
pivot_table2 = pd.pivot_table(df, values='销售额', index=['地区'], aggfunc='sum')

print("\n按地区汇总销售额:")
print(pivot_table2)

按地区汇总销售额:

地区
华北    32000
华东    33000
华南     8000
华中    13000
Name: 销售额, dtype: int64

示例3: 按地区和销售员汇总销售额,并显示每个组合的平均销售额

假设我们想要按地区和销售员汇总销售额,并显示每个组合的平均销售额。

# 生成数据透视表
pivot_table3 = pd.pivot_table(df, values='销售额', index=['地区', '销售员'], aggfunc='mean')

print("\n按地区和销售员汇总销售额(平均值):")
print(pivot_table3)

按地区和销售员汇总销售额(平均值):

地区  销售员
华东  张三    11000.0
华北  李四    12000.0
      王五    20000.0
华南  王五     5500.0
华中  李四     9333.333333
      王五     6000.0
Name: 销售额, dtype: float64

示例4: 按地区和销售员汇总销售额,并显示每个组合的最大销售额

假设我们想要按地区和销售员汇总销售额,并显示每个组合的最大销售额。

# 生成数据透视表
pivot_table4 = pd.pivot_table(df, values='销售额', index=['地区', '销售员'], aggfunc='max')

print("\n按地区和销售员汇总销售额(最大值):")
print(pivot_table4)输出结果

按地区和销售员汇总销售额(最大值):

地区  销售员
华东  张三    15000
华北  李四    12000
      王五    20000
华南  王五     5000
华中  李四     7000
      王五     6000
Name: 销售额, dtype: int64

结论

通过以上示例,我们可以看到Pandas库在处理数据透视表方面提供了非常强大和灵活的功能。无论是简单的汇总还是复杂的多条件聚合,Pandas都能轻松应对。掌握这些基本技巧后,你将能够更加高效地管理和分析自己的数据集,从而更快地获得有价值的洞察。希望这篇文章能帮助你在日常工作中更好地利用Pandas!

到此这篇关于使用Pandas实现Excel中的数据透视表的项目实践的文章就介绍到这了,更多相关Pandas Excel数据透视表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解Python中__new__和__init__的区别与联系

    详解Python中__new__和__init__的区别与联系

    在Python中,每个对象都有两个特殊的方法:__new__和__init__,本文将详细介绍这两个方法的不同之处以及它们之间的联系,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • python学习实操案例(四)

    python学习实操案例(四)

    这篇文章主要介绍了python学习实操案例,这一篇小编给大家带来的是列表,所以这里是和列表有关的案例,需要的小伙伴可以参考一下,希望对你有所帮助<BR>
    2022-02-02
  • 利用Python绘制一个可爱的米老鼠

    利用Python绘制一个可爱的米老鼠

    turtle库是一个点线面的简单图像库,在Python2.6之后被引入进来,能够完成一些比较简单的几何图像可视化。本文将利用turtle绘制一个可爱的米老鼠,感兴趣的可以试一试
    2022-03-03
  • Python设计模式之代理模式简单示例

    Python设计模式之代理模式简单示例

    这篇文章主要介绍了Python设计模式之代理模式,简单说明了代理模式的概念、原理,并结合Python实例形式分析了代理模式的相关定义与使用技巧,需要的朋友可以参考下
    2018-01-01
  • python GUI库图形界面开发之PyQt5美化窗体与控件(异形窗体)实例

    python GUI库图形界面开发之PyQt5美化窗体与控件(异形窗体)实例

    这篇文章主要介绍了python GUI库图形界面开发之PyQt5美化窗体与控件(异形窗体)实例,需要的朋友可以参考下
    2020-02-02
  • Django中引入bootstrap的详细图文详解

    Django中引入bootstrap的详细图文详解

    Django是基于Python的一个Web开发框架,可以实现前端和后台间的数据连接,下面这篇文章主要给大家介绍了关于Django中引入bootstrap的相关资料,需要的朋友可以参考下
    2022-10-10
  • Python利用pyreadline模块实现交互式命令行开发

    Python利用pyreadline模块实现交互式命令行开发

    交互式命令行是一种方便用户进行交互的工具,能够使用户与计算机进行快速的交互操作,提高工作效率。本文主要介绍了如何利用pyreadline模块实现交互式命令行开发,需要的可以参考一下
    2023-05-05
  • Python使用flask-caching缓存数据的示例代码

    Python使用flask-caching缓存数据的示例代码

    Flask-Caching 是 Flask 的一个扩展,为任何 Flask 应用程序添加了对各种后端的缓存支持,它基于 cachelib 运行,并通过统一的 API 支持 werkzeug 的所有原始缓存后端,本文给大家介绍了Python使用flask-caching缓存数据,需要的朋友可以参考下
    2024-12-12
  • python列表使用实现名字管理系统

    python列表使用实现名字管理系统

    这篇文章主要为大家详细介绍了python列表使用实现名字管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • Python pyinstaller库的安装配置教程分享

    Python pyinstaller库的安装配置教程分享

    pyinstaller模块主要用于python代码打包成exe程序直接使用,这样在其它电脑上即使没有python环境也是可以运行的。本文就来和大家分享一下pyinstaller库的安装配置教程,希望对大家有所帮助
    2023-04-04

最新评论