python 的DataFrame 数据里面有不可转换为float的非纯数字字符串,怎么转换

在Python中,当DataFrame中存在无法转换为浮点数的非纯数字字符串时,需要进行数据清理。通过使用`astype()`尝试转换会引发错误。解决方案是定义一个自定义函数,利用`try-except`结构来处理异常,将非转换的字符串设为0。具体做法是应用`apply()`函数结合自定义的转换函数,从而成功完成数据类型转换。
摘要由CSDN通过智能技术生成

python 的DataFrame 数据里面有不可转换为float的非纯数字字符串,怎么转换

一个bug改了半天,查了无数文章,终于改好了,我可太激动了,记录下来

traffic_feature[column[3]] = new_feature[3].astype('float') / traffic['LaneNum'] / traffic['length']

new_feature[3].astype(‘float’) 这里报错

could not convert string to float:

我把数据打印出来,发现确实有一行没有数据 也不知道是空格还是什么不能显示的字符

然后改成了

def convert_currency(var):
    try:
        var = float(var)
    except:
        var = 0.0
    return var
 traffic_feature[column[3]] = new_feature[3].apply(convert_currency)/ traffic['LaneNum'] / traffic['length']

总结:astype转换只能转换纯数字,不能忽略错误。。。要数据清理要自定义函数。。。学会了try和except的使用方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值