首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用regex替换仅在特定列上的列值

使用regex替换仅在特定列上的列值
EN

Stack Overflow用户
提问于 2021-01-05 13:41:59
回答 3查看 1.2K关注 0票数 0

我想替换特定列的值。我可以一个一个地更改值,但是,我有数百个列,我需要更改以特定字符串开头的列。下面是一个示例,当列名以"Q14"开头时,我想替换该字符串

代码语言:javascript
复制
df.filter(regex = 'Q14').replace(1, 'Selected').replace(0, 'Not selected')

上面的代码正在工作。但是,如何在我的dataframe中实现它呢?因为这是函数所以我不能在里面使用。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-01-05 13:54:53

请考虑下面的df

代码语言:javascript
复制
In [439]: df = pd.DataFrame({'Q14_A':[ 1,0,0,2], 'Q14_B':[0,1,1,2], 'Q12_A':[1,0,0,0]})

In [440]: df
Out[440]: 
   Q14_A  Q14_B  Q12_A
0      1      0      1
1      0      1      0
2      0      1      0
3      2      2      0

筛选以Q14开头的列,将其保存在变量中:

代码语言:javascript
复制
In [443]: cols = df.filter(regex='^Q14').columns

现在,使用您的replace命令更改上述选定的列:

代码语言:javascript
复制
In [446]: df[cols] = df[cols].replace(1, 'Selected').replace(0, 'Not selected')

输出:

代码语言:javascript
复制
In [447]: df
Out[447]: 
          Q14_A         Q14_B  Q12_A
0      Selected  Not selected      1
1  Not selected      Selected      0
2  Not selected      Selected      0
3             2             2      0
票数 2
EN

Stack Overflow用户

发布于 2021-01-05 13:46:01

您可以遍历所有列,并根据匹配的条件使用apply命令应用列转换:

代码语言:javascript
复制
for column in df.columns:
    if column.startswith("Q"):
        df[column] = df[column].apply(lambda x: "Selected" if x == 1 else "Not selected")
票数 1
EN

Stack Overflow用户

发布于 2021-01-05 14:46:24

使用pandas.Series.replace dict

代码语言:javascript
复制
df = pd.DataFrame({'Q14_A':[ 1,0,0,2], 'Q14_B':[0,1,1,2], 'Q12_A':[1,0,0,0]})
cols = df.filter(regex='^Q14').columns

replace_map = {
    1: "Selected",
    0 : "Not Selected"

}

df[cols] = df[cols].replace(replace_map)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65580064

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档