另一种解决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的空缺值。
另一种解决AttributeError: ‘numpy.int64‘ object has no attribute ‘translate‘的方法_第1张图片
这样在转换类型的时候,就会很麻烦。

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

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

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

你可能感兴趣的:(Python,python,numpy,mysql)