AttributeError: 'numpy.int64' object has no attribute 'translate'

在用pymysql将dataframe数据逐行写入数据库时,报AttributeError: ‘numpy.int64’ object has no attribute 'translate’这个错误。

报错原因:将dataframe该行中是数值型数据的字段的类型打印出来,发现该字段是numpy.int64类型,但是在数据库中对应要写入的字段是int型的。

解决方法:在该行中numpy.int64类型的字段类型转为int型的。例如像下面这样,将line[“cluster_category_code”]转化为int型即可。

sql = "UPDATE cs_cluster_keywords_info SET after_filter_keywords = %s WHERE keyword_id = %s and cluster_category_code = %s"
        print(type(line["cluster_category_code"]))
        cursor.execute(sql, [line["after_filter_keywords"], keywordId,int(line["cluster_category_code"])])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值