返回顶部
首页 > 资讯 > 后端开发 > Python >Python中怎么实现一个透视表
  • 120
分享到

Python中怎么实现一个透视表

2023-06-16 12:06:59 120人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

本篇文章为大家展示了python中怎么实现一个透视表,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 数据为帮助大家更好地理解,在讲解如何使用pivot_table( )实现透视表前,我们先导入示

本篇文章为大家展示了python中怎么实现一个透视表,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1. 数据

为帮助大家更好地理解,在讲解如何使用pivot_table( )实现透视表前,我们先导入示例数据,在接下来的讲解中都使用此数据作为例子。

# 导入示例数据 <<< datadata =pd.read_csv("data.csv") <<< data.head()     月份  项目  部门   金额       剩余金额 0   1月  水费  市场部 1962.37    8210.58 1   2月  水费  市场部 690.69     9510.60 2   2月  电费  市场部 2310.12    5384.92 3   2月  电费  运营部 -1962.37   7973.10 4   2月  电费  开发部 1322.33    6572.16

下面我将带大家使用pivot_table( )一步一步实现数据透视表的操作。

2. 操作

首先,原数据有5个字段,我们在做数据透视表之前必须理解每个字段的意思,明确清楚自己需要得到什么信息。

假设我们想看看不同月份所花费的水电费金额是多少,这时我们需要把字段“月份”设置为索引,将字段“金额”设置为我们需要看的值,具体代码如下:

<<< data.pivot_table(index=['月份'],values=['金额'])            金额 月份   10月 3723.940000 11月 2900.151667 12月 10768.262857 1月  1962.370000 2月  1432.280000 3月  3212.106667 4月  4019.175000 5月  4051.480000 6月  6682.632500 7月  11336.463333 8月  17523.485000 9月  10431.960000

参数index为设置的索引列表,即分组依据,需要用中括号[ ]将索引字段括起来;参数values为分组后进行计算的字段列表,也需要用中括号[  ]括起来。这两个参数的值可以是一个或多个字段,即按照多个字段进行分组和对多个字段进行计算汇总。例如,设置index=['项目','部门']代表求不同项目不同部门下的金额。

<<< data.pivot_table(index=['项目','部门'],values=['金额'])             金额 项目  部门   水费  市场部  3614.318125      开发部   2358.205000      运营部   5896.213333 电费  市场部   6094.748235       开发部   1322.330000       运营部   7288.615000 采暖费 市场部   5068.380000       运营部   55978.000000

若设置values=['金额','剩余金额'],即求不同项目不同部门下金额和剩余金额的值。

<<< data.pivot_table(index=['项目','部门'],values=['金额','剩余金额'])               剩余金额       金额 项目  部门       水费  市场部    7478.423125  3614.318125       开发部   6866.490000   2358.205000       运营部   7224.033333   5896.213333 电费  市场部    7645.535882   6094.748235       开发部   6572.160000    1322.330000       运营部   8821.895000    7288.615000 采暖费 市场部   6572.030000    5068.380000       运营部   7908.560000    55978.000000

同时,如果我们想以交叉表的形式查看不同项目和不同部门下的消费金额,这时就要将字段&lsquo;部门&rsquo;设置为列名,进行交叉查看,具体代码如下:

<<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额'])       金额 部门   市场部        开发部     运营部 项目           水费   3614.318125  2358.205  5896.213333 电费   6094.748235  1322.330  7288.615000 采暖费  5068.380000  NaN      55978.000000

通过上面的示例,我们可以看到某个分组下不存在记录会被标记为NAN,例如上述中采暖部和开发部不存在金额这一字段的记录,则会标记为NAN。如果不希望被标记为NAN,我们可以通过设置参数fill_value=0来用数值0替代这部分的缺失值。

<<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额'],fill_value=0)       金额 部门   市场部        开发部     运营部 项目           水费   3614.318125  2358.205  5896.213333 电费   6094.748235  1322.330  7288.615000 采暖费  5068.380000  0.000    55978.000000

在上面的示例中,我们都是默认分组后对值进行求平均值计算,假如我们想查看不同项目不同部门下金额的总和该怎么实现呢?

通过设置参数aggfunc=np.sum即可对分组后的值进行求和操作,参数aggfunc代表分组后值的汇总方式,可传入numpy库中的聚合方法。

<<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额'],fill_value=0,aggfunc=np.sum) 金额 部门    市场部      开发部    运营部 项目           水费    57829.09   4716.41   17688.64 电费    103610.72  1322.33   29154.46 采暖费   5068.38    0.00     55978.00

除了常见的求和、求平均值这两种聚合方法,我们还可能接触到以下这几种:

描述方法标准差np.std()方差np.var()所有元素相乘np.prod()中数np.median()幂运算np.power()开方np.sqrt()最小值np.min()最大值np.max()以e为底的指数np.exp(10)对数np.log(10)

与前面介绍的参数index,columns,value一样,参数aggfunc传入的值也是一个列表,表示可传入一个或多个值。当传入多个值时,表示对该值进行多种汇总方式,例如同时求不同项目不同部门下金额的求和值和平均值:

<<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额'],fill_value=0,aggfunc=[np.sum,np.max])      sum               amax      金额               金额 部门  市场部 开发部 运营部 市场部 开发部 运营部 项目                       水费  57829.09  4716.41  17688.64 16807.58 2941.28 6273.56 电费  103610.72 1322.33  29154.46 18239.39 1322.33 26266.60 采暖费 5068.38   0.00    55978.00  5068.38  0.00    55978.00

同时,如果我们想对不同字段进行不同的汇总方式,可通过对参数aggfunc传入字典来实现,例如我们可以同时对不同项目不同部门下,对字段金额求总和值,对字段剩余金额求平均值:

<<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额','剩余金额'],fill_value=0,aggfunc={'金额':np.sum,'剩余金额':np.max})      剩余金额                  金额 部门  市场部   开发部   运营部   市场部     开发部     运营部 项目                       水费  9510.60 8719.34 7810.38 57829.09   4716.41  17688.64 电费  9625.27 6572.16 9938.82 103610.72  1322.33  29154.46 采暖费 6572.03 0.00    7908.56 5068.38    0.00     55978.00

另外,在进行以上功能的同时,pivot_table还为我们提供了一个求所有行及所有列对应合计值的参数margins,当设置参数margins=True时,会在输出结果的最后添加一行'All',表示根据columns进行分组后每一项的列总计值;以及在输出结果的最后添加一列'All',表示根据index进行分组后每一项的行总计值。

<<< pd.set_option('precision',0) <<< data.pivot_table(index=['项目'],columns=['部门'],values=['金额','剩余金额'],fill_value=0,aggfunc={'金额':np.sum,'剩余金额':np.max},margins=True)      剩余金额                 金额 部门  市场部 开发部 运营部 All   市场部  开发部  运营部  All 项目                               水费  9511  8719  7810  9511  57829  4716   17689  80234 电费  9625  6572  9939  9939  103611  1322  29154  134088 采暖费 6572  0     7909  7909  5068    0     55978  61046 All   9625  8719  9939  9939  166508  6039  102821 275368

3. 番外

上面详细介绍了如何在Python中通过pivot_table(  )方法实现数据透视表的功能,那么,与数据透视表原理相同,显示方式不同的&lsquo;数据透视图&rsquo;又该怎么实现呢?

实现方法非常简单,将上述进行pivot_table操作后的对象进行实例化,再对实例化后的对象进行plot绘图操作即可,具体代码如下:

<<< dfdf=data.pivot_table(index=['项目'],columns=['部门'],values='金额',fill_value=0) <<< df.plot(kind='bar')
Python中怎么实现一个透视表

上述内容就是Python中怎么实现一个透视表,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网Python频道。

--结束END--

本文标题: Python中怎么实现一个透视表

本文链接: https://lsjlt.com/news/283614.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python中怎么实现一个透视表
    本篇文章为大家展示了Python中怎么实现一个透视表,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 数据为帮助大家更好地理解,在讲解如何使用pivot_table( )实现透视表前,我们先导入示...
    99+
    2023-06-16
  • Python+Pandas实现数据透视表
    目录导入示例数据参数说明常用操作大家好,我是丁小杰。 对于数据透视表,相信对于 Excel 比较熟悉的小伙伴都知道如何使用它,并了解它的强大之处,而在pandas中要实现数据透视就要...
    99+
    2024-04-02
  • 怎么使用Python+Pandas实现数据透视表
    这篇文章主要介绍了怎么使用Python+Pandas实现数据透视表的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python+Pandas实现数据透视表文章都会有所收获,下面我们一起来看看吧。导入示例数...
    99+
    2023-07-02
  • Python如何实现数据透视表
    这篇文章主要为大家展示了“Python如何实现数据透视表”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python如何实现数据透视表”这篇文章吧。用Python里的Pandas可以实现,虽然感觉...
    99+
    2023-06-25
  • Python实现数据透视表详解
    目录1.groupby + agg2. crosstab3.groupby + pivotpivot_table总结用Python里的Pandas可以实现,虽然感觉Excel更方便 ...
    99+
    2024-04-02
  • MySQL/MariaDB怎么实现数据透视表
    这篇文章将为大家详细讲解有关MySQL/MariaDB怎么实现数据透视表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用 CASE 表达式和分组聚合数据透视表的本质就是按照行和列的不同组合进行数据分组,...
    99+
    2023-06-14
  • Unity怎么实现透视滑动列表
    本篇内容主要讲解“Unity怎么实现透视滑动列表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Unity怎么实现透视滑动列表”吧!本文实例为大家分享了Unity实现透视滑动列表的具体代码,供大家...
    99+
    2023-06-20
  • 怎么在CSS3中实现一个酷炫的3D旋转透视效果
    本篇文章给大家分享的是有关怎么在CSS3中实现一个酷炫的3D旋转透视效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。CSS3 3D 转换的常用API介绍首先先上一张css 3...
    99+
    2023-06-08
  • Oracle中如何实现数据透视表
    这篇文章主要介绍Oracle中如何实现数据透视表,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!使用 CASE 表达式实现数据透视表数据透视表的本质就是按照行和列的不同组合进行数据分组,然后对结果进行汇总;因此,它和数...
    99+
    2023-06-14
  • 一文搞懂Python中pandas透视表pivot_table功能
    目录一、概述1.1 什么是透视表?1.2 为什么要使用pivot_table?二、如何使用pivot_table2.1 读取数据2.2Index2.3Values2.4Aggfunc...
    99+
    2024-04-02
  • Unity实现透视滑动列表
    本文实例为大家分享了Unity实现透视滑动列表的具体代码,供大家参考,具体内容如下 1、目的 有时候,为了实现更好的美术效果,需要实现一些特殊的滑动列表,例如轨迹滑动,也有透视滑动。...
    99+
    2024-04-02
  • PHP中怎么实现一个表单
    PHP中怎么实现一个表单,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。$_GET 和 $_POST 用于检索表单中的值,比如用户输入。PHP表单处理PHP表单实例:<&n...
    99+
    2023-06-17
  • 怎么在html中实现一个表格
    怎么在html中实现一个表格?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。html做表格的方法:首先新建一个html,并在“”中间填入表格内容;然后在“”中间输入样式表的样式;...
    99+
    2023-06-14
  • excel数据透视表怎么做
    要创建一个Excel数据透视表,可以按照以下步骤进行操作:1. 打开Excel并导入数据。确保数据以表格的形式排列,并且每列都有一个...
    99+
    2023-09-16
    excel
  • Java中怎么创建Excel 数据透视表
    今天就跟大家聊聊有关Java中怎么创建Excel 数据透视表,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。使用工具:Free Spire.XLS for JavaJar文件...
    99+
    2023-06-02
  • Python实现多个视频合成一个视频的功能
    目录前言环境依赖代码验证一下前言 本文提供将多个视频拼接为一个视频的Python工具代码,其中有一些限制条件,下面的代码说明会提到。 环境依赖 ffmpeg环境安装,可以参考:win...
    99+
    2024-04-02
  • Javascript中怎么实现一个伪哈希表
    这期内容当中小编将会给大家带来有关Javascript中怎么实现一个伪哈希表,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。javascript中实现哈希表的代码:1 fu...
    99+
    2024-04-02
  • Echarts中怎么实现一个树形图表
    Echarts中怎么实现一个树形图表,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。树图主要用来可视化树形数据结构,是一种特殊的层次类型。实现方法,将series->t...
    99+
    2023-06-20
  • C++中怎么实现一个单向链表
    C++中怎么实现一个单向链表,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。C++单向链表实现代码:#include < iostream>&...
    99+
    2023-06-17
  • Excel数据透视表怎么制作
    这篇文章主要介绍“Excel数据透视表怎么制作”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Excel数据透视表怎么制作”文章能帮助大家解决问题。数据透视表制作方法:首先,我们选中需要制作数据表的所...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作