另一种解决AttributeError: ‘numpy.int64‘ object has no attribute ‘translate‘的方法

在python的编程中,使用pandas自带的to_sql方法写数据库时,遇到了“AttributeError: ‘numpy.int64’ object has no attribute ‘translate’”的报错。

解决的方法在最下面加粗字体
在这里插入图片描述
上网查了一下,说是numpy.int64类型的原因,就是说原先的dataframe里的数字是int64类型,写数据库需要int类型,所以报错。

网上大多的方法是转换类型,例如,int(),df.astype(int),但是我的dataframe里面,不止有int类型,还有float,以及nan的空缺值。
在这里插入图片描述
这样在转换类型的时候,就会很麻烦。

因为脚本在windows平台写的,运行没问题,上linux之后才报的错,所以换了一个思路。

首先升级pandas,然后升级numpy,然后又升级了pymysql,sqlalchemy,这个时候发现不报错了。

猜测应该是pymysql后来的版本对这个问题进行了修复。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值