DataFrame列转行列表及重塑技巧
学习知识要善于思考,思考,再思考!今天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学习网公众号了解相关技术文章。
多列布局最后一列高度不一致?CSSbreak-inside解决分栏错乱
- 上一篇
- 多列布局最后一列高度不一致?CSSbreak-inside解决分栏错乱
- 下一篇
- 网易大神被禁言怎么查?
-
- 文章 · python教程 | 28分钟前 |
- Python手写数字识别模型训练教程
- 195浏览 收藏
-
- 文章 · python教程 | 34分钟前 |
- Python3用逗号连接字符串方法简单
- 410浏览 收藏
-
- 文章 · python教程 | 39分钟前 | Python入门
- Pythonfor循环如何部分求和
- 226浏览 收藏
-
- 文章 · python教程 | 45分钟前 | Python编程 format函数
- Python格式化函数全解析
- 443浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Pythonpandas教程:核心功能详解
- 485浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- PythonCSV时间计算教程
- 268浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python邮件发送教程实战详解
- 384浏览 收藏
-
- 文章 · python教程 | 2小时前 | Python
- Pythonprint()函数使用详解
- 317浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Pandas数据框按列排序技巧
- 237浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python图像识别神经网络入门教程
- 462浏览 收藏
-
- 文章 · python教程 | 2小时前 |
- Python用Pygal做图表教程
- 323浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3500次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3726次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3725次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4869次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4095次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览

