python使用MySQLdb写数据库时中文乱码问题

在用python做写数据库的客户端时, 发生了写入的中文数据为乱码的问题。经过查找资料,发现为客户端连接时的编码方式问题。

使用MySQLdb包。

问题如下图:


后来在连接数据库时,进行了编码方式的设置charset="utf8",就没问题了。代码段如下:

import MySQLdb
conn = MySQLdb.connect(
        host = '192.168.1.20',
        port = 3306,
        user = 'root',
        passwd = 'test',
        db = 'test',
        charset="utf8",
        )

cur = conn.cursor()
for i in range(REGION_NUM):
    mip = "0.0.0.%d"%(i)
    region = code_to_region[i].split('_')
    region_en = region[0]
    operator_en = region[1]

    region_cn = region_dict[region_en]
    operator_cn = operator_dict[operator_en]

    command = "INSERT INTO `test`.`qlljx_region` (`id`, `mip`, `region`, `province_en`, " \
                "`province_cn`, `operator_en`, `operator_cn`) VALUES ('%d', '%s', '%s', '%s', '%s', '%s', '%s');" \
                %(i, mip, code_to_region[i], region_en, region_cn, operator_en, operator_cn)
    print command
    cur.execute(command)



最后的结果如下图:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值