zoukankan      html  css  js  c++  java
  • 分享一点python 编码设置的知识

    昨天我写了个python 操作mysql的方法,按照文档的提供的参数来写,写完了以后自己测试发现报了一个编码的错误,也不知道为什么会报这个错误,我一般对编码的错误比较在意,原来搞php的时候,就出现过读取数据库里的信息编码错误,后来我吸取了教训,用php读取数据库数据按照一套标准来走就没有出现过编码的问题。

    我的标准是:设置4个地方编码一致。
    1数据库编码
    2数据表编码
    3程序文件编码
    4读取数据之前设置好编码

    我现在用python读取mysql数据库的时候就遇到:数据库错误: 'ascii' codec can't encode characters in position 0-4: ordinal not in range(128)

    我检查了下各处的编码,数据库,数据表和文件的编码都是utf-8,都是一致的,那为什么还是会出现编码的问题呢?
    我想应该是读取数据之前没有设置默认的编码,接着我查了下文档,发现了解决办法。

    我通过sys模块的setdefaultencoding('编码类型')来进行python 编码设置

    下面给出我的代码:
    #encoding=utf-8
    import sys
    import MySQLdb

    reload(sys)
    sys.setdefaultencoding('utf-8')

    看来应该先设置好编码类型,再读取数据就不会出错了。

     作者:老王@python python 教程 老王python,提供python相关的python 书籍,python 主机,django 教程和python 下载,希望大家能够喜欢!

  • 相关阅读:
    UVA11464偶数矩阵
    UVA11464偶数矩阵
    UVA11462年龄排序
    UVA11462年龄排序
    UVA11427玩纸牌(全概率+递推)
    UVA11427玩纸牌(全概率+递推)
    UVA11389巴士司机问题
    LA3644简单并查集判环
    LA3027简单带权并查集
    LA3027简单带权并查集
  • 原文地址:https://www.cnblogs.com/wanpython/p/1930491.html
Copyright © 2011-2022 走看看