pythonforin替换字符_如何在pandas.Dataframe中替换字符串的一部分?

我试图替换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 :(注意:有时列表理解比字符串/对象dtypes的内部向量化方法更快)

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)

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

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值