大家好,我是你们的东哥。
【pandas100个骚操作|pandas100个骚操作五(使用 explode 实现 pandas 列转行的 2 个常用技巧)】本篇是pandas100个骚操作的第5篇:使用 explode 实现 pandas 列转行的 2 个常用技巧
查看全部骚操作可以点击专栏:pandas 100个骚操作
在我们处理数据的过程中,经常会遇到这样的情况。
文章图片
工作中比如用户画像的数据中,客户使用的app类型就会以这种长列表的形式或者以逗号隔开的字符串形式展现出来。
那么面对这样的数据格式,我们希望把它转换为结构化的表,脑海中想象的是下面这种格式。
文章图片
使用pandas
如何实现呢?
一、直接explode 其实非常简单,使用explode
这爆炸方法即可,东哥平时喜欢叫它爆炸。其实,这个和hive
中的lateral view explode
有异曲同工的效果,也就是列转行的功能。
仍用上面这个例子,要达到想要的效果,只需要这么做。
df.explode('爱好')
文章图片
看到爱好这个字段被爆炸开了,列表里所有特征都被转换为对应程序员的行数据。
但列表有重复的值,就可能导致爆炸出来的行存在重复行,如上面小码哥出现了两次敲代码。所以一般我们会在后面跟一个去重的方法。
df.explode('爱好').drop_duplicates()
文章图片
二、explode不能直接处理的 但是,
explode
这个爆炸方法只能处理列表
、元组
、Series
和numpy
的ndarray
的类型。如果面对下面这种格式,该如何爆炸?
文章图片
其实也不难,只要运用一个小技巧即可,就是
Series.str.split()
分割字符串的方法来创建列表。df["爱好"] = df["爱好"].str.split()
文章图片
然后,我们再用
explode
爆炸就完事了。以上就是本次关于
explode
的骚操作分享。我是东哥,和我一起学pandas 100个骚操作,欢迎关注我的原创公众号:Python数据科学
推荐阅读
- 前端与Python|Pandas 函数方法汇总一览查询(持续补充改进)
- # yyds干货盘点 # 盘点一个Pandas中explode()爆炸函数应用实际案例
- # yyds干货盘点 # 盘点6个Pandas中批量替换字符的方法
- Python Pandas库教程(超详细)
- Python Pandas tseries.offsets.DateOffset用法介绍
- 100 个 pandas 案例,强烈建议收藏!
- Python与机器学习|pandas中如何提取DataFrame的某些列
- 让开发人员的生活更轻松的十大Python工具
- python|用scikit-learn和pandas学习线性回归