Pandas之八Reshaping(一)

简介: 数据分析时,有时会要对数据做一些变形才能更好地分析,Pandas提供了灵活的方法应对该场景,包括`stack`和`pivot table`

数据分析时,有时会要对数据做一些变形才能更好地分析,Pandas提供了灵活的方法应对该场景,包括stackpivot table

  • stack:将dataframe中的列转为行。
  • pivot table:数据透视表,功能比较丰富,大多数场景都可适用。

下面使用图中两套数据对这两个功能进行说明

1. Stack

Stack提供了行转列与列转行的操作,使用.stack将列转为行,还可以使用.unstack将行转为列(stack的逆操作),返回的是SeriesDataFrame

1.1 Stack

将dataframe中指定level的列转为行,在上图数据列是单层,其列的level值既是0(类似于列表下标从0开始)也是-1(同列表下标倒数)。

  • level的默认值为-1,即将最内层的列转为行
  • 若dataframe中的列是单层,返回的是一个Series
  • 若dataframe有多层列,返回的是一个将指定level列转为行的dataframe

对示例数据做列转行操作

  1. 将最内层列(level=-1)转为行

    # 以下写法效果一致
    df8.stack()
    df8.stack(-1)
    df8.stack(1)

  1. 将weight转为行,(level=0level=-2

    df8.stack(0)
    df8.stack(-2)

  1. 将所有列都转为行,此时返回Series,同时可以看到其有多重索引

    s1=df8.stack([0,1])

1.2 unstack

unstackstack的逆操作,将DataFrame或Series中指定level的index转为列。

  • level值默认为-1,即将最内层的index转为列
  • 如果index只有一层,返回的值将是一个Series
  • 若index有多层,而未全部转为列,返回的值是一个DataFrame

对上文中的结果s1执行.unstack操作

  1. 将最内层index转为列

    # 以下语句执行效果一致
    s1.unstack()
    s1.unstack(-1)
    s1.unstack(2)

  1. 将中间层index转为列

    s1.unstack(1)
    s1.unstack(-2)

  1. 将多个index转为列

    s1.unstack([1,2])

目录
相关文章
|
Python
Pandas之八Reshaping(二)
聊聊透视表功能,该功能和Excel中的数据透视功能相似。pivot:对原始DataFrame进行变形整理。pivot table:可以在数据变形整理的基础上,做数据聚合操作。
263 0
Pandas之八Reshaping(二)
|
SQL 索引 Python
Pandas之三选择数据
介绍在pandas中筛选数据的几种方法,快速定位某行、某列、具体元素的方法
828 0
Pandas之三选择数据
|
数据库 Python
Pandas之二查看数据
通过pandas查看dataframe的数据,包括head、tail、index、columns、describe、T、sort_index和sort_values
356 0
Pandas之二查看数据
|
6月前
|
分布式计算 大数据 数据处理
别说你会用Pandas
别说你会用Pandas
34 0
|
SQL 数据挖掘 BI
Pandas之五数据操作
pandas进行数据分析的常用功能:系统函数统计、自定义函数统计、数值计数、字符串函数。
192 0
Pandas之五数据操作
|
机器学习/深度学习 数据可视化 数据挖掘
5 个pandas神级操作,最后一个长见识了!
最近发现了几个pandas的骚操作,小巧实用,个个经典,下面快速介绍下。
|
7月前
|
数据采集 数据挖掘 数据格式
pandas怎么用
【7月更文挑战第9天】pandas怎么用
46 2
|
9月前
|
存储 缓存 Rust
Polars (最强Pandas平替)
Polars (最强Pandas平替)
282 1
|
数据挖掘 索引 Python
Python数据分析之pandas基本数据结构
Python数据分析之pandas基本数据结构
Python数据分析之pandas基本数据结构
|
9月前
|
SQL 机器学习/深度学习 数据处理
10个Pandas的高级技巧
Pandas是我们最常用的数据处理Python库之一。尽管您可能已经与它共事多年,但可能还有许多您尚未探索的实用方法。我将向您展示一些可能未曾听说但在数据整理方面非常实用的方法。
172 0

热门文章

最新文章