Pandas DataFrame替换某字符而非字符串

文章讲述了作者在处理股市数据时遇到的问题,如何使用pandas的replace方法无法替换特定字符逗号,通过将DataFrame转换为字符串并逐列进行replace操作,最终解决字符替换问题的过程和遇到的错误及解决方案。

起因是这样,楼主要处理一些股价数据,但是有的股价是1,000这样的形式,中间带着个‘,’于是楼主需要处理一下。

网上找到的绝大部分方法都让你使用df.replace()方法,但是此方法只能替换每个数据,而不能替换数据的子部分。也就是说,它只能替换字符串,而很难替换某字符:

ARHab=ARHab.replace(',','')
print(ARHab)
ARHab = pd.DataFrame(ARHab, dtype=float) #df的值转化为浮点数

输出结果为:

替换失败。

即使是加了inplace=True也无济于事

ARHab=ARHab.replace(',','',inplace=True)
print(ARHab)
ARHab = pd.DataFrame(ARHab, dtype=float)

直接给我df干置空了。

后来发现只能替换字符串,而很难替换某字符,这样写了代码:

for index, column in ARHab.iteritems(): # 去除所有的','按列遍历df
    ARHab.loc[:,index]=ARHab.loc[:,index].str.replace(",","") #使用字符串的replace
ARHab = pd.DataFrame(ARHab, dtype=float)

但是报了这样的错:

AttributeError: Can only use .str accessor with string values!

 在前面加了一行先转换为字符串的代码,终于成功:

ARHab = ARHab.astype(str)
for index, column in ARHab.iteritems(): # 去除所有的','按列遍历df
    ARHab.loc[:,index]=ARHab.loc[:,index].str.replace(",","") #使用字符串的replace
ARHab = pd.DataFrame(ARHab, dtype=float)

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值