gpt4 book ai didi

python Pandas 替换字符串中的单词

转载 作者:太空宇宙 更新时间:2023-11-03 12:44:34 26 4
gpt4 key购买 nike

给定一个像这样的数据框:

A    B    C
1 a yes
2 b yes
3 a no

我想将数据框更改为:

A    B    C
1 a yes
2 b no
3 a no

这意味着如果 B 列的值为“b”,我想将 C 列更改为“no”。可以用 df[df['B']=='b']['C'].str.replace('yes','no') 表示。但是使用它不会改变数据框 df 本身。即使我尝试过 df[df['B']=='b']['C'] = df[df['B']=='b']['C'].str.replace( '是','否') 它没有用。我想知道如何解决这个问题。

最佳答案

通过mask设置值的解决方案:

df.loc[df.B == 'b', 'C'] = 'no'
print (df)
A B C
0 1 a yes
1 2 b no
2 3 a no

df['C'] = df['C'].mask(df.B == 'b','no')
print (df)
A B C
0 1 a yes
1 2 b no
2 3 a no

仅替换 yes 字符串的解决方案:

df.loc[df.B == 'b', 'C'] = df['C'].replace('yes', 'no')
print (df)
A B C
0 1 a yes
1 2 b no
2 3 a no

df['C'] = df['C'].mask(df.B == 'b', df['C'].replace('yes', 'no'))
print (df)
A B C
0 1 a yes
1 2 b no
2 3 a no

在更改后的 df 中可以更好地看到差异:

print (df)
A B C
0 1 a yes
1 2 b yes
2 3 b another
3 4 a no

df['C_set'] = df['C'].mask(df.B == 'b','no')
df['C_replace'] = df['C'].mask(df.B == 'b', df['C'].replace('yes', 'no'))

print (df)
A B C C_set C_replace
0 1 a yes yes yes
1 2 b yes no no
2 3 b another no another
3 4 a no no no

编辑:

在你的解决方案中只需要添加loc:

df.loc[df['B']=='b', 'C'] = df.loc[df['B']=='b', 'C'].str.replace('yes','no')
print (df)
A B C
0 1 a yes
1 2 b no
2 3 b another
3 4 a no

编辑1:

我真的很好奇什么方法最快:

#[40000 rows x 3 columns]
df = pd.concat([df]*10000).reset_index(drop=True)
print (df)

In [37]: %timeit df.loc[df['B']=='b', 'C'] = df['C'].str.replace('yes','no')
10 loops, best of 3: 79.5 ms per loop

In [38]: %timeit df.loc[df['B']=='b', 'C'] = df.loc[df['B']=='b','C'].str.replace('yes','no')
10 loops, best of 3: 48.4 ms per loop

In [39]: %timeit df.loc[df['B']=='b', 'C'] = df.loc[df['B']=='b', 'C'].replace('yes','no')
100 loops, best of 3: 14.1 ms per loop

In [40]: %timeit df['C'] = df['C'].mask(df.B == 'b', df['C'].replace('yes', 'no'))
100 loops, best of 3: 10.1 ms per loop

# piRSquared solution with replace
In [53]: %timeit df.C = np.where(df.B.values == 'b', df.C.replace('yes', 'no'), df.C.values)
100 loops, best of 3: 4.74 ms per loop

编辑1:

更好的是更改条件 - 如果需要最快的解决方案,请添加 df.C == 'yes'df.C.values == 'yes':

df.loc[(df.B == 'b') & (df.C == 'yes'), 'C'] = 'no'

df.C = np.where((df.B.values == 'b') & (df.C.values == 'yes'), 'no', df.C.values)

关于python Pandas 替换字符串中的单词,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43555834/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com