DataFrame列转行列表及重塑技巧
时间:2025-12-30 18:36:40 100浏览 收藏
学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《DataFrame列转行列表及透视重塑方法》,以下内容主要包含等知识点,如果你正在学习或准备学习文章,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

本教程详细介绍了如何利用Pandas库高效地将DataFrame中的多列数据聚合为每行的列表,并在此基础上进行数据透视(pivot)操作,以实现复杂的DataFrame重塑需求。文章通过具体示例,深入讲解了`assign()`、`apply()`和`pivot()`等核心方法的联合应用,旨在帮助读者掌握一种避免冗余循环、提升数据处理效率的专业技巧。
在数据分析和处理过程中,我们经常需要对Pandas DataFrame进行复杂的重塑操作。一个常见的场景是,需要将DataFrame中的若干列数据合并成一个列表,作为新的一列,然后根据其他列的值进行透视,将特定的列转换为新的索引或列名。本文将以一个具体的示例,详细阐述如何通过链式操作,高效地实现这一数据转换过程,避免使用低效的循环语句。
原始数据结构
假设我们有一个包含产品ID、名称、多个数值列以及类型信息的DataFrame,其结构如下:
import pandas as pd
import io
data = """id name value1 value2 value3 Type
1 AAA 1.0 1.5 1.8 NEW
2 BBB 2.0 2.3 2.5 NEW
3 CCC 3.0 3.6 3.7 NEW"""
df = pd.read_csv(io.StringIO(data), sep=r'\s+')
print("原始DataFrame:")
print(df)输出:
原始DataFrame: id name value1 value2 value3 Type 0 1 AAA 1.0 1.5 1.8 NEW 1 2 BBB 2.0 2.3 2.5 NEW 2 3 CCC 3.0 3.6 3.7 NEW
目标数据结构
我们的目标是将value1、value2、value3这三列的数据合并成一个列表,作为每个name对应的新值,并以Type作为索引,name作为新的列名,最终形成如下结构:
Type AAA BBB CCC ================================================================ NEW [1.0, 1.5, 1.8] [2.0, 2.3, 2.5] [3.0, 3.6, 3.7]
解决方案:链式操作实现数据重塑
要实现上述转换,我们可以利用Pandas的assign()、apply()和pivot()方法进行链式操作。
1. 将多列数据合并为列表
首先,我们需要将value1到value3这几列的数据,在每一行中合并成一个列表。这可以通过df.loc选择特定列,然后使用apply(list, axis=1)方法实现。axis=1参数至关重要,它指示apply函数按行操作,将每一行选定列的值作为列表传递。
# 提取需要合并的列,并按行生成列表 df.loc[:, 'value1':'value3'].apply(list, axis=1)
这将返回一个Series,其中每个元素都是一个列表:
0 [1.0, 1.5, 1.8] 1 [2.0, 2.3, 2.5] 2 [3.0, 3.6, 3.7] dtype: object
2. 使用 assign() 添加新列
接下来,我们将这个包含列表的新Series添加回原始DataFrame,作为名为value的新列。assign()方法是一个非常方便的函数,它可以在不修改原始DataFrame的情况下,返回一个添加了新列的新DataFrame。
df.assign(value=df.loc[:, 'value1':'value3'].apply(list, axis=1))
执行此步骤后,DataFrame将包含一个名为value的新列,其中存储了合并后的列表。
3. 使用 pivot() 进行数据透视
最后一步是使用pivot()方法进行数据透视。pivot()函数需要三个关键参数:
- index: 指定新DataFrame的索引列。
- columns: 指定新DataFrame的列名来源列。
- values: 指定填充新DataFrame单元格的值来源列。
根据我们的目标结构,Type应作为索引,name作为列名,而我们刚刚创建的value列则作为透视后的数据值。
(df.assign(value=df.loc[:, 'value1':'value3'].apply(list, axis=1)) .pivot(index='Type', columns='name', values='value'))
4. 清理和格式化(可选但推荐)
透视操作完成后,Pandas可能会为新的列名(name)和索引(Type)添加一个层级名称(name和Type)。为了使输出更简洁,我们可以使用rename_axis(None, axis=1)移除列名的层级名称,并通过reset_index()将Type从索引转换为普通列。
(df.assign(value=df.loc[:, 'value1':'value3'].apply(list, axis=1)) .pivot(index='Type', columns='name', values='value') .rename_axis(None, axis=1) # 移除列名轴的名称 .reset_index()) # 将Type从索引转换为列
完整代码示例
将上述步骤整合,形成完整的解决方案代码:
import pandas as pd
import io
# 模拟原始DataFrame
data = """id name value1 value2 value3 Type
1 AAA 1.0 1.5 1.8 NEW
2 BBB 2.0 2.3 2.5 NEW
3 CCC 3.0 3.6 3.7 NEW"""
df = pd.read_csv(io.StringIO(data), sep=r'\s+')
# 执行转换操作
transformed_df = (
df.assign(value=df.loc[:, 'value1':'value3'].apply(list, axis=1))
.pivot(index='Type', columns='name', values='value')
.rename_axis(None, axis=1)
.reset_index()
)
print("\n转换后的DataFrame:")
print(transformed_df)输出结果
转换后的DataFrame: Type AAA BBB CCC 0 NEW [1.0, 1.5, 1.8] [2.0, 2.3, 2.5] [3.0, 3.6, 3.7]
注意事项与总结
- 效率: 这种方法避免了Python的显式循环,充分利用了Pandas底层的C/NumPy优化,因此对于大型数据集来说效率非常高。
- pivot() vs pivot_table(): pivot()要求index和columns的组合必须是唯一的,否则会报错。如果存在重复组合,且需要进行聚合操作(如求和、平均等),则应使用功能更强大的pivot_table()。在本例中,Type和name的组合是唯一的,因此pivot()适用。
- loc选择器: 使用df.loc[:, 'value1':'value3']可以精确选择连续的列,确保只对目标列进行操作。
- 链式操作: 将多个操作链接在一起(使用括号包裹,并换行),可以提高代码的可读性和简洁性。
通过掌握assign()、apply()和pivot()的联合使用,您将能够灵活高效地处理DataFrame的复杂重塑任务,极大地提升数据处理能力。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《DataFrame列转行列表及重塑技巧》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
316 收藏
-
195 收藏
-
410 收藏
-
226 收藏
-
443 收藏
-
485 收藏
-
268 收藏
-
384 收藏
-
317 收藏
-
237 收藏
-
462 收藏
-
323 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习