python向数据库插入报错InternalError: (pymysql.err.InternalError) (1366, "Incorrect string value: '\\xE6\\xAD

本文详细介绍了使用pymysql向数据库插入数据时遇到的编码错误,包括UnicodeEncodeError和InternalError,并提供了相应的解决方案,如调整连接参数和更改表的字符集。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用pymysql向数据库中插入数据报错:

错误一:

UnicodeEncodeError: 'latin-1' codec can't encode characters in position 133-145: ordinal not in range(256)

错误原因:数据与数据库中字符编码不相同

解决方法:pymysql.connect()中添加charset='utf8'

错误二:

InternalError: (pymysql.err.InternalError) (1366, "Incorrect string value: '\\xE6\\xAD

错误原因:未知

解决方法:运行命令   mysql> alter table 表名 convert to character set utf8mb4;

错误三:

'latin-1' codec can't encode characters in position 32-34: ordinal not in range(256)

错误原因:不能识别输入的中文

解决方法:value = value.encode("utf-8").decode("latin1")  #value是你输入的中文

 
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值