gpt4 book ai didi

python - 如何替换 pandas.Dataframe 中的部分字符串?

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

我正在尝试替换 pd.Dataframe 中所有字符串的一部分,但它不起作用。

我的数据示例:

HLAA0101    
HLAA0201
HLAA0202
HLAA0203
HLAA0205

我想得到什么:

A0101    
A0201
A0202
A0203
A0205

我的代码:

 mhc = train_csv.mhc

for i in mhc:
i[0:2].replace('HLA', ' ')

print(mhc)

但它不起作用。

最佳答案

选项 1:

df['mhc'] = df['mhc'].str[3:]

选项 2:

df['mhc'] = df['mhc'].str.replace(r'^HLA','')

选项 3:

df['mhc'] = df['mhc'].str.extract(r'HLA(.*)', expand=False)

选项 4:(注意:对于字符串/对象数据类型,有时列表理解比内部向量化方法更快)

df['mhc'] = [s[3:] for s in df['mhc']]

所有选项产生相同的结果:

In [26]: df
Out[26]:
mhc
0 A0101
1 A0201
2 A0202
3 A0203
4 A0205

50.000 行 DF 的时间:

In [29]: df = pd.concat([df] * 10**4, ignore_index=True)

In [30]: %timeit df['mhc'].str[3:]
35.9 ms ± 3.18 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)

In [31]: %timeit df['mhc'].str.replace(r'^HLA','')
162 ms ± 3.04 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)

In [32]: %timeit df['mhc'].str.extract(r'HLA(.*)', expand=False)
164 ms ± 4.87 ms per loop (mean ± std. dev. of 7 runs, 10 loops each)

In [33]: %timeit [s[3:] for s in df['mhc']]
14.6 ms ± 18.6 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)

In [34]: df.shape
Out[34]: (50000, 1)

结论:列表理解方法获胜。

关于python - 如何替换 pandas.Dataframe 中的部分字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50433473/

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