前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >pandas 行列转换的 2 个常用技巧!

pandas 行列转换的 2 个常用技巧!

作者头像
Python数据科学
发布2023-08-29 19:23:27
1380
发布2023-08-29 19:23:27
举报
文章被收录于专栏:Python数据科学Python数据科学

本次给大家介绍关于pandas 行列转换2个常用技巧。

在我们处理数据的过程中,经常会遇到这样的情况。

工作中,比如用户画像的数据中也会遇到,客户使用的app类型就会以这种长列表的形式或者以逗号隔开的字符串形式展现出来。

那么面对这样的数据格式,我们希望把它转换为结构化的表,脑海中想象的是下面这种格式。

使用pandas如何实现呢?

一、直接explode

其实非常简单,使用explode这个 “爆炸” 方法即可,东哥平时喜欢叫它爆炸。其实,这个和hive中的lateral view explode有异曲同工的效果,也就是 “列转行” 的功能。

仍用上面这个例子,要达到想要的效果,只需要这么做。

代码语言:javascript
复制
df.explode('爱好')

看到爱好这个字段被爆炸开了,列表里所有特征都被转换为对应程序员的行数据。

但列表有重复的值,就可能导致爆炸出来的行存在重复行,如上面小码哥出现了两次敲代码。所以一般我们会在后面跟一个去重的方法。

代码语言:javascript
复制
df.explode('爱好').drop_duplicates()

二、explode不能直接处理的

但是,explode这个爆炸方法只能处理列表元组Seriesnumpyndarray的类型。

如果面对下面这种格式,该如何爆炸?

其实也不难,只要运用一个小技巧即可,就是Series.str.split()分割字符串的方法来创建列表。

代码语言:javascript
复制
df["爱好"] = df["爱好"].str.split()

然后,我们再用explode爆炸就完事了。

以上就是本次关于 列转行 的2个骚操作分享。

推荐阅读

👉pandas进阶宝典

👉数据挖掘实战项目

👉机器学习入门

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-07-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python数据科学 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、explode不能直接处理的
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档