盘点6个Pandas中批量替换字符的方法
大家好,我是Python进阶者。
一、前言
前几天在Python最强王者群有个叫【dcpeng】的粉丝问了一个关于Pandas中的问题,这里拿出来给大家分享下,一起学习。
想问一下我有一列编码为1,2,3,4的数据,如何将1批量换为“开心”,2批量换为“悲伤”这种字符替换呢?
二、解决过程
思路挺简单,限定Pandas处理,想到的方法有很多,这里拿出来给大家分享,希望对大家的学习有帮助。
![](https://img.haomeiwen.com/i26239789/64ef216c004510b2.png)
下面这个是生成源数据的代码:
df = pd.DataFrame({'col1': [1, 2, 2, 3, 3, 3, 4, 4, 4, 4]})
方法一:【月神】解答
代码如下所示:
df['col2'] = df['col1'].map({1:"开心", 2:"悲伤", 3:"难过", 4:"泪目"})
运行结果如下图所示:
![](https://img.haomeiwen.com/i26239789/849cbee913f104f5.png)
方法二:【dcpeng】解答
这个方法是参考才哥的文章写出来的,代码如下所示:
def getValue(s):
if s==1:
return '开心'
elif s==2:
return '悲伤'
elif s==3:
return '难过'
elif s==4:
return '泪目'
df['col3'] = df['col1'].apply(getValue)
df
运行结果如下图所示:
![](https://img.haomeiwen.com/i26239789/39de61b3057ca8b0.png)
方法三:【冫马讠成】解答
【冫马讠成】大佬给了一个思路,使用replace
实现。
![](https://img.haomeiwen.com/i26239789/3c852a3b5ba77a17.png)
代码如下所示:
df['col4'] = df['col1'].replace(1, '开心').replace(2, '悲伤').replace(3, '难过').replace(4, '泪目')
得到的结果如下所示:
![](https://img.haomeiwen.com/i26239789/d98e46ab93439d0d.png)
方法四:【dcpeng】解答
这个方法是基于apply()函数,代码如下所示:
def get_value(s):
dict = {1:"开心", 2:"悲伤", 3:"难过", 4:"泪目"}
return dict[s]
df['col5'] = df['col1'].apply(get_value)
df
运行结果如下图所示:
![](https://img.haomeiwen.com/i26239789/822595eb5aff6982.png)
方法五:【沈复】解答
【沈复】大佬给了一个思路和代码,如下图所示:
![](https://img.haomeiwen.com/i26239789/22e7ada8b404bde4.png)
这个方法是基于map()函数,代码如下所示:
def get_value(s):
dict = {1:"开心", 2:"悲伤", 3:"难过", 4:"泪目"}
return dict[s]
df['col5'] = df['col1'].map(get_value)
df
运行结果如下图所示:
![](https://img.haomeiwen.com/i26239789/a52181c9aea4469b.png)
方法六:【月神】解答
这里【月神】仍然是使用replace
方法进行实现的,但是代码秀了很多。
![](https://img.haomeiwen.com/i26239789/4515b03169dd35cb.png)
代码如下所示:
df['col7'] = df['col1'].replace([1, 2, 3, 4], ['开心', '悲伤', '难过', '泪目'])
【月神】提醒:这个是全匹配,不要加regex=True参数,不然你会后悔的!
运行结果如下图所示:
![](https://img.haomeiwen.com/i26239789/71a6f6b872c48bfe.png)
三、总结
大家好,我是Python进阶者。这篇文章基于粉丝提问,针对有一列编码为1,2,3,4的数据,如何将1批量换为“开心”,2批量换为“悲伤”这种字符替换的问题,盘点了6个Pandas中批量替换字符的方法,给出了具体说明和演示,顺利地帮助粉丝解决了问题!
最后感谢粉丝【dcpeng】提问,感谢【🌑(这是月亮的背面)】和【dcpeng】、【才哥】、【沈复】、大佬给出的示例和代码支持。感谢粉丝【冫马讠成】、【老松鼠】等人参与学习交流。
![](https://img.haomeiwen.com/i26239789/3c8363811c079fbd.png)