在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后来的版本对这个问题进行了修复。