新闻中心
Pandas数据框中按组生成递增序列ID的教程

本文介绍如何在pandas数据框中,为每一行生成一个复合id,其中包含基于字符串截取的部分以及一个递增的序列号。核心挑战在于当特定列(如`city`)的值发生变化时,该序列号需要重新从1开始计数。教程将详细阐述如何利用pandas的`groupby()`和`cumcount()`函数,高效地实现这种按组重置的序列id生成逻辑,确保生成的id既具有唯一性又符合业务逻辑,并提供清晰的代码示例。
在数据处理和分析中,为数据集中的记录生成唯一标识符(ID)是一项常见任务。这些ID通常由多个部分组成,例如从现有字符串中提取的片段和顺序编号。一个常见的需求是,当某个特定的分组字段(如城市、类别等)发生变化时,序列号需要重新从1开始计数。
理解按组序列ID的需求
假设我们有一个包含城市(City)和姓名(Name)的数据框,我们希望生成一个复合ID,格式为城市前三字符-姓名前三字符-序列号。这里的关键在于,当城市发生变化时,序列号应该重新从1开始计算,而不是在整个数据框中连续递增。
例如,对于以下数据:
| City | Name |
|---|---|
| Paris | John |
| Paris | Paul |
| Paris | Pierre |
| Paris | Paula |
| Rome | Riccardo |
| Rome | Jean-Paul |
| Rome | Franc |
我们期望的ID输出是:
| City | Name | Id |
|---|---|---|
| Paris | John | Par-Joh-1 |
| Paris | Paul | Par-Pau-2 |
| Paris | Pierre | Par-Pie-3 |
| Paris | Paula | Par-Pau-4 |
| Rome | Riccardo | Rom-Ric-1 |
| Rome | Jean-Paul | Rom-Jea-2 |
| Rome | Franc | Rom-Fra-3 |
如果直接使用数据框的索引作为序列号(例如 df.index.astype(str)),则序列号将是全局递增的,无法实现按组重置的效果。
核心解决方案:利用 groupby() 和 cumcount()
Pandas库提供了强大的数据分组和聚合功能,其中groupby()结合cumcount()是解决此类问题的理想工具。
- df.groupby('分组列'): 这个方法用于根据指定的一个或多个列的值对数据框进行分组。它返回一个GroupBy对象,后续的操作将在每个分组内部独立执行。
- cumcount(): 这是GroupBy对象的一个方法,它在每个分组内部生成一个从0开始递增的序列号。例如,对于一个包含3个元素的组,cumcount()将生成 0, 1, 2。
- add(1): 由于cumcount()是0-indexed(从0开始计数),而我们通常希望ID从1开始,所以需要使用add(1)将其转换为1-indexed。
- astype(str): 最后,将生成的数字序列转换为字符串类型,以便与ID的其他字符串部分进行拼接。
逐步实现与代码示例
让我们通过一个具体的代码示例来演示如何实现这一功能。
VALL-E
VALL-E是一种用于文本到语音生成 (TTS) 的语言建模方法
134
查看详情
首先,创建示例数据框:
import pandas as pd
data = {
'City': ['Paris', 'Paris', 'Paris', 'Paris', 'Rome', 'Rome', 'Rome'],
'Name': ['John', 'Paul', 'Pierre', 'Paula', 'Riccardo', 'Jean-Paul', 'Franc']
}
df = pd.DataFrame(data)
print("原始数据框:")
print(df)输出:
原始数据框:
City Name
0 Paris John
1 Paris Paul
2 Paris Pierre
3 Paris Paula
4 Rome Riccardo
5 Rome Jean-Paul
6 Rome Franc接下来,应用groupby().cumcount()方法来生成符合要求的ID:
# 生成按城市分组的递增序列号
# df.groupby('City').cumcount() 会为每个城市组内生成 0, 1, 2...
# .add(1) 将其变为 1, 2, 3...
# .astype(str) 将数字转换为字符串以便拼接
sequential_id = df.groupby('City').cumcount().add(1).astype(str)
# 提取城市和姓名的前三个字符
city_prefix = df.City.str[:3]
name_prefix = df.Name.str[:3]
# 组合所有部分生成最终的ID
df['Id'] = city_prefix + '-' + name_prefix + '-' + sequential_id
print("\n生成ID后的数据框:")
print(df)输出:
生成ID后的数据框:
City Name Id
0 Paris John Par-Joh-1
1 Paris Paul Par-Pau-2
2 Paris Pierre Par-Pie-3
3 Paris Paula Par-Pau-4
4 Rome Riccardo Rom-Ric-1
5 Rome Jean-Paul Rom-Jea-2
6 Rome Franc Rom-Fra-3可以看到,Id列已经按照预期生成,当City从Paris变为Rome时,序列号成功地从1重新开始计数。
代码解析
df['id'] = (df.City.str[:3] + '-' + df.Name.str[:3] +'-' + df.groupby('City').cumcount().add(1).astype(str))
- df.City.str[:3]: 提取City列每个字符串的前三个字符。
- df.Name.str[:3]: 提取Name列每个字符串的前三个字符。
- df.groupby('City'): 根据City列的值对数据框进行分组。
- .cumcount(): 在每个City分组内部,生成一个从0开始的累积计数。
- 例如,对于Paris组,它会生成0, 1, 2, 3。
- 对于Rome组,它会生成0, 1, 2。
- .add(1): 将cumcount()生成的序列号加1,使其从1开始计数。
- Paris组变为1, 2, 3, 4。
- Rome组变为1, 2, 3。
- .astype(str): 将数字序列转换为字符串类型。
- 最后,使用+运算符将所有字符串部分连接起来,形成最终的Id。
注意事项与扩展
- 多列分组: 如果需要根据多列进行分组并重置序列号,只需在groupby()中传入一个列名列表即可,例如 df.groupby(['City', 'Country']).cumcount()。
-
序列号格式化: 如果希望序列号有固定位数(例如 01, 02, 03),可以在astype(str)之后使用str.zfill()方法。例如:
sequential_id_padded = df.groupby('City').cumcount().add(1).astype(str).str.zfill(2) df['Id_Padded'] = df.City.str[:3] + '-' + df.Name.str[:3] + '-' + sequential_id_padded - 性能: groupby().cumcount()是Pandas高度优化的操作,对于大型数据集,其性能远优于使用循环或apply自定义函数的方式。
总结
通过巧妙地结合Pandas的groupby()和cumcount()方法,我们可以高效且简洁地解决在数据框中按组生成递增序列ID的问题。这种方法不仅代码可读性强,而且在处理大规模数据时也能保持良好的性能。掌握这一技巧,将有助于您在数据预处理和特征工程中更加灵活地构建符合业务逻辑的唯一标识符。
以上就是Pandas数据框中按组生成递增序列ID的教程的详细内容,更多请关注其它相关文章!
# 如何用
# 威海网站建设的报价
# 广东推广网站方式
# 安平网站建设推广
# 保定外贸网站推广
# 营销公司 游戏推广
# 培训互动网站推广文案
# 玉林公司网站建设全包
# 广东网站推广怎么样
# 巫溪新媒体短视频矩阵营销推广
# 网站建设流程联系电话
# 前三
# app
# 它会
# 将其
# 运算符
# 多个
# 这一
# 转换为
# 框中
# 自定义
# 代码可读性
# 工具
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异
CSS条件样式无法按设备触发怎么排查_media条件语句正确设置解决触发问题
海棠电脑版入口_通过电脑访问海棠官网阅读
俄罗斯搜索引擎Yandex指南 附2025年免登录官网入口
怎样使用“本地安全策略”提升Windows安全性_Secpol.msc配置指南【高手】
TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法
192.168.1.1管理中心入口 192.168.1.1路由器网页设置平台
在React函数组件中利用原生HTML5进行邮箱地址验证
PySpark中高效提取字符串右侧可变长度数字:使用regexp_extract
QQ邮箱登录首页官网地址2026 QQ邮箱官方网页入口
GemBox Document HTML转PDF垂直文本渲染问题及解决方案
React Hooks最佳实践:动态组件状态管理的组件化方案
探索高级语言到C/C++的转译路径:以Go为例及内存管理策略
J*aScript中正确使用querySelectorAll与复杂CSS选择器
Yandex官网免登录入口_俄罗斯Yandex搜索引擎一键访问
Lar*el的路由模型绑定怎么用_Lar*el Route Model Binding简化控制器逻辑
J*aScript map 迭代中检测空数组元素的有效方法
深入理解J*a编译器的兼容性选项:从-source到--release
Centos/Linux 系统下安装 composer 的完整步骤
抖音创作助手登录入口_抖音创作辅助工具官网直达
C++如何实现一个装饰器模式_C++设计模式之动态地给对象添加额外职责
在WordPress中通过REST API获取BasicAuth保护的远程文章
为什么我的微信朋友圈看不到别人的更新_微信朋友圈更新显示异常解决方法
PHP URL参数传递与500错误调试指南
Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性
厨房不锈钢水槽发黑生锈怎么处理_水槽用可乐+锡纸2分钟抛亮如新
J*aScript设计模式实践_j*ascript代码优化
包子漫画官方网站在线链接-包子漫画在线阅读平台主页地址
Win10系统怎么查看已安装更新_Win10卸载有问题的更新补丁
win11 Snap Layouts怎么用 Win11窗口布局与分屏多任务高效指南【必学】
Composer中的^和~符号代表什么_精通Composer版本号语义化约束
J*aScript数据结构转换:将对象数组按类别分组
菜鸟取件码是什么怎么查 最全查询渠道汇总
PyTorch模型训练效果不佳?深入剖析常见错误与调试技巧
Golang如何实现容器化日志收集与分析_Golang容器日志收集分析方法
漫蛙2正版漫画站 漫蛙2网页版快速访问入口
Pygame教程:解决用户输入与游戏状态更新不同步问题
实现分段式页面滚动导航:CSS与J*aScript教程
Win10自动更新怎么关闭 Win10永久关闭系统更新的两种方法【终极版】
将HTML动态表格多行数据保存到Google Sheet的教程
PostgreSQL海量数据高效导入策略:Python与Django实践指南
PyTorch模型训练准确率不提升:诊断与修复常见指标计算错误
天眼查企业查询官网入口 天眼查官方网页版查询
微博网页版官方账号登录 微博网页版内容浏览使用指南
文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】
J*a里如何实现线程安全的懒加载单例_懒加载单例实现方法解析
如何修改开机登录密码_Windows账户安全设置超详细教程【必学】
网易大神账号申诉需要多久_网易大神账号申诉流程说明
uc浏览器网页版入口 uc浏览器网页版最新网址
Win11怎么用U盘重装系统 Win11制作启动盘并重装系统完整教程【详解】


2025-11-04
浏览次数:次
返回列表
.str[:3] +'-' +
df.groupby('City').cumcount().add(1).astype(str))