0

0

如何将 Pandas DataFrame 高效转换为多级嵌套字典

心靈之曲

心靈之曲

发布时间:2026-01-23 17:17:02

|

917人浏览过

|

来源于php中文网

原创

如何将 Pandas DataFrame 高效转换为多级嵌套字典

本文介绍一种无需双重 for 循环的简洁方法,利用 `groupby().apply()` 的嵌套调用,将 dataframe 按多个列分组并转换为深度嵌套字典(如 `{col1: {col2: [{record}, ...]}}`,兼顾可读性与性能。

在数据处理中,常需将扁平化的 DataFrame 转换为结构化嵌套字典,以适配 API 请求、配置生成或前端树形渲染等场景。传统双重 for 循环虽直观,但代码冗长、可维护性差,且难以扩展至三层及以上层级。

Pandas 提供了更优雅的函数式方案:通过链式 groupby().apply() 实现多级嵌套。核心思路是逐层分组,并在最内层将子 DataFrame 转为记录列表(to_dict(orient='records')),外层则自动聚合为字典。

以下为推荐实现(兼容 pandas ≥ 1.3):

Axiom
Axiom

Axiom是一个浏览器扩展,用于自动化重复任务和web抓取。

下载
import pandas as pd

# 构造示例数据(同原问题)
a = pd.DataFrame([
    {'col1': 'A', 'col2': 'Person 1', 'height': 1, 'weight': 10},
    {'col1': 'A', 'col2': 'Person 1', 'height': 2, 'weight': 20},
    {'col1': 'A', 'col2': 'Person 2', 'height': 4, 'weight': 40},
    {'col1': 'B', 'col2': 'Person 1', 'height': 11, 'weight': 101},
    {'col1': 'B', 'col2': 'Person 2', 'height': 41, 'weight': 401},
])

# ✅ 推荐:单行嵌套 groupby + apply
result = (
    a.groupby('col1')
     .apply(lambda x: x.groupby('col2').apply(lambda y: y.to_dict('records')))
     .to_dict()
)

该写法输出结构与原始双循环完全一致:外层键为 'col1' 值(如 'A'),中层键为 'col2' 值(如 'Person 1'),末层为对应分组的完整记录列表(含所有原始字段)。

⚠️ 注意事项:to_dict() 在 Series 上默认返回 {'index': value} 形式,但此处因 apply() 返回的是 pd.Series(索引为 col2 值,值为列表),调用 .to_dict() 会自动映射为 {col2_value: record_list},无需额外处理;若需支持 三层嵌套(如 col1 → col2 → col3),可继续嵌套:.groupby('col1').apply(...).groupby('col2').apply(...).groupby('col3').apply(...).to_dict(),但建议封装为递归函数提升可读性;对于超大数据集,apply 可能略慢于向量化操作;若仅需特定字段,可先用 [['col2', 'height', 'weight']] 选择列以减少内存开销。

总结:相比显式循环,此方法更符合 pandas 函数式编程范式,逻辑清晰、扩展性强,且一行核心代码即可完成多级结构构建,是生产环境中推荐的标准实践。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

54

2025.12.04

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

8

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

18

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

18

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

10

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

10

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

30

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 9.2万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.8万人学习

Vue 教程
Vue 教程

共42课时 | 7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号