0

0

Pandas中为每个类别重复显示所有分箱并填充零计数的教程

花韻仙語

花韻仙語

发布时间:2025-12-12 21:31:37

|

516人浏览过

|

来源于php中文网

原创

Pandas中为每个类别重复显示所有分箱并填充零计数的教程

本教程旨在解决如何在pandas dataframe中,为每个分类组(如“continent”)完整展示所有预定义的分箱(如“rank”)并对那些在原始数据中未出现的分类-分箱组合填充零计数。我们将通过创建辅助列、使用`groupby`进行聚合,并结合`unstack`和`stack`操作来高效实现这一目标,确保数据分析的完整性和可视化的一致性。

在数据分析实践中,我们经常需要对数据进行分类和分箱统计。然而,默认的聚合操作只会显示实际存在的数据组合。当我们需要确保所有预定义的分箱(bins)都呈现在每个类别(category)下,即使某些组合的计数为零时,就需要采取额外的步骤。这对于保持数据结构的一致性、进行可视化或后续分析至关重要。

1. 准备初始数据

首先,我们从一个包含分类(如“Continent”)和已分箱数据(如“Rank”)的DataFrame开始。这个DataFrame反映了每个大陆下不同分箱的原始记录。

import pandas as pd

# 示例原始数据
data = {
    'Continent': [
        'Asia', 'North America', 'Asia', 'Europe', 'Europe',
        'North America', 'Europe', 'Asia', 'Europe', 'Asia',
        'Europe', 'Europe', 'Asia', 'Australia', 'South America'
    ],
    'Rank': [
        '(15.753, 29.227]', '(2.212, 15.753]', '(2.212, 15.753]',
        '(2.212, 15.753]', '(15.753, 29.227]', '(56.174, 69.648]',
        '(15.753, 29.227]', '(2.212, 15.753]', '(15.753, 29.227]',
        '(2.212, 15.753]', '(29.227, 42.701]', '(29.227, 42.701]',
        '(2.212, 15.753]', '(2.212, 15.753]', '(56.174, 69.648]'
    ]
}
df = pd.DataFrame(data)

print("原始DataFrame:")
print(df)

2. 计算每个(分类,分箱)组合的计数

Pandas的groupby().count()方法默认需要一个列来进行计数。如果直接对多个列进行groupby().count(),它会尝试对所有非分组列进行计数。为了简单地获取每个组合的行数,我们可以添加一个辅助列。

# 添加一个辅助列,用于计数
df['count_col'] = 1

# 按 'Continent' 和 'Rank' 分组并计数
# as_index=False 将分组键保留为列
grouped_counts = df.groupby(['Continent', 'Rank'], as_index=False)['count_col'].count()

# 重命名计数列以便更清晰
grouped_counts = grouped_counts.rename(columns={'count_col': 'Count'})

print("\n按(Continent, Rank)分组后的计数(不含零值):")
print(grouped_counts)

此时,grouped_counts DataFrame只包含实际在原始数据中出现的Continent-Rank组合及其计数。例如,如果某个大陆的某个分箱没有数据,它将不会出现在这个结果中。

Mureka
Mureka

Mureka是昆仑万维最新推出的一款AI音乐创作工具,输入歌词即可生成完整专属歌曲。

下载

3. 包含零计数的完整分箱展示

为了让每个大陆都显示所有可能的分箱,即使其计数为零,我们可以利用unstack()和stack()的组合操作。

  1. unstack(): 这个操作可以将指定级别的索引转换为列。当我们将Rank作为索引并unstack()时,它会为每个Continent创建一个行,并将所有Rank值作为列。如果某个Continent-Rank组合不存在,Pandas会默认填充NaN。
  2. fill_value=0: 在unstack()时,我们可以通过fill_value=0参数将所有缺失值(NaN)替换为零。这是实现零计数的关键一步。
  3. stack(): stack()是unstack()的逆操作,它将列索引转换回行索引。经过unstack(fill_value=0)后,stack()会把填充了零的宽格式数据重新转换回长格式,从而包含所有Continent-Rank组合,包括那些原本为零的。
  4. reset_index(): 最后,reset_index()将多级索引转换回常规列,得到一个整洁的DataFrame。
# 使用 unstack 和 stack 来填充零值
# 首先,将 'Continent' 和 'Rank' 设置为索引
df_indexed = df.set_index(['Continent', 'Rank'])

# 添加一个辅助列用于计数,并进行groupby
# 这里直接在设置索引后的DataFrame上进行计数
final_result = df_indexed.groupby(level=['Continent', 'Rank']).size().unstack(fill_value=0).stack().reset_index()

# 重命名计数列
final_result.columns = ['Continent', 'Rank', 'Count']

print("\n包含零计数的完整(Continent, Rank)组合:")
print(final_result)

通过上述步骤,我们成功地为每个大陆展示了所有可能的分箱,并用零填充了那些在原始数据中没有记录的组合。

注意事项与总结

  • 辅助计数列或.size(): 在groupby()之后,可以使用.count()(如果DataFrame中有其他列)或.size()(直接计算分组大小)来获取每个分组的行数。在本教程的最终解决方案中,我们使用了.size(),它更简洁地计算了每个分组的大小。
  • unstack()的fill_value: fill_value参数是确保零值填充的关键。没有它,unstack()会将不存在的组合填充为NaN,stack()后这些NaN仍然会存在或被丢弃(取决于dropna参数)。
  • 灵活性: 这种groupby().unstack().stack()的模式在Pandas中非常强大,不仅可以用于计数,还可以用于其他聚合函数(如求和、平均值等),以确保在多维度分析中数据的完整性。

掌握这种技术,能够帮助数据分析师和工程师在处理分类和分箱数据时,生成更全面、更易于理解和分析的报告。

相关专题

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

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

51

2025.12.04

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.20

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

534

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

14

2026.01.06

数据分析的方法
数据分析的方法

数据分析的方法有:对比分析法,分组分析法,预测分析法,漏斗分析法,AB测试分析法,象限分析法,公式拆解法,可行域分析法,二八分析法,假设性分析法。php中文网为大家带来了数据分析的相关知识、以及相关文章等内容。

464

2023.07.04

数据分析方法有哪几种
数据分析方法有哪几种

数据分析方法有:1、描述性统计分析;2、探索性数据分析;3、假设检验;4、回归分析;5、聚类分析。本专题为大家提供数据分析方法的相关的文章、下载、课程内容,供大家免费下载体验。

278

2023.08.07

网站建设功能有哪些
网站建设功能有哪些

网站建设功能包括信息发布、内容管理、用户管理、搜索引擎优化、网站安全、数据分析、网站推广、响应式设计、社交媒体整合和电子商务等功能。这些功能可以帮助网站管理员创建一个具有吸引力、可用性和商业价值的网站,实现网站的目标。

724

2023.10.16

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.8万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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