欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python sqlobject(mysql)中文亂碼解決方法

 更新時間:2008年11月14日 22:51:59   作者:  
在使用python寫項目的時候,用到了sqlobject庫函數(shù)connectionForURI連接mysql,但是遇到了中文顯示亂碼的問題,在添加記錄的時候還拋出異常
UnicodeEncodeError: 'latin-1' codec can't encode characters in position;
找了一天終于搞明白了,默認情況下,mysql連接的編碼是latin-1,你需要指定使用什么編碼方式:
connectionForURI(mysql://user:password@localhost:3306/eflow?use_unicode=1&charset=utf8)

Python mysql 中文亂碼 的解決方法,有需要的朋友不妨看看。
 
先來看一段代碼:

復制代碼 代碼如下:

import MySQLdb
  db_user = "tiger"
  db_pw = "tiger"
  db = MySQLdb.connect(host="localhost", user=db_user, passwd=db_pw ,db="finaltldw",charset="gb2312")
  c = db.cursor()
  c.execute("""select id, name from NODES""")
  i=0;
  for id, name in c.fetchall():
   print "%2d %s" % (id, name)
   i=i+1
   if i==100:
   break

返回結(jié)果:
  1 TOP
  2 教育
  3 機構(gòu)
  4 人
  5 地區(qū)
  6 單位
  7 科學研究
  8 實驗室
  9 類型
    
  如果編碼是UTF-8
  轉(zhuǎn)載一個解決方案: 其中的use db
  
  Python操作MySQL以及中文亂碼的問題
  Python操作MySQL需要安裝Python-MySQL
  可以從網(wǎng)上搜索一下,和一般的Python包一樣安裝
  
  安裝好之后,模塊名字叫做MySQLdb ,在Window和Linux環(huán)境下都可以使用,試驗了一下挺好用,
  不過又發(fā)現(xiàn)了煩人的亂麻問題,最后用了幾個辦法,解決了!
  
  我用了下面幾個措施,保證MySQL的輸出沒有亂麻:
   1 Python文件設(shè)置編碼 utf-8 (文件前面加上 #encoding=utf-8)
   2 MySQL數(shù)據(jù)庫charset=utf-8
   3 Python連接MySQL是加上參數(shù) charset=utf8
   4 設(shè)置Python的默認編碼為 utf-8 (sys.setdefaultencoding(utf-8)
  mysql_test.py 

復制代碼 代碼如下:

#encoding=utf-8
  import sys
  import MySQLdb
  
  reload(sys)
  sys.setdefaultencoding('utf-8')
  
  db=MySQLdb.connect(user='root',charset='utf8')
  cur=db.cursor()
  cur.execute('use mydb')
  cur.execute('select * from mytb limit 100')
  
  f=file("/home/user/work/tem.txt",'w')
  
  for i in cur.fetchall():
   f.write(str(i))
   f.write(" ")
  
  f.close()
  cur.close()

上面是linux上的腳本,windows下運行正常!
  
  注:MySQL的配置文件設(shè)置也必須配置成utf8
  
  設(shè)置 MySQL 的 my.cnf 文件,在 [client]/[mysqld]部分都設(shè)置默認的字符集(通常在/etc/mysql/my.cnf):
  [client]
  default-character-set = utf8
  [mysqld]
  default-character-set = utf8

相關(guān)文章

  • Django中使用MySQL5.5的教程

    Django中使用MySQL5.5的教程

    這篇文章主要介紹了Django中使用MySQL5.5的教程,本文圖文實例詳解的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • Django和Ueditor自定義存儲上傳文件的文件名

    Django和Ueditor自定義存儲上傳文件的文件名

    這篇文章主要介紹了Django和Ueditor自定義存儲上傳文件的文件名,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • AI與Python人工智能遺傳算法

    AI與Python人工智能遺傳算法

    這篇文章主要為大家介紹了AI與Python人工智能遺傳算法的詳解教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • 使用PyTorch常見4個錯誤解決示例詳解

    使用PyTorch常見4個錯誤解決示例詳解

    這篇文章主要為大家介紹了使用PyTorch常見4個錯誤解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 一文搞懂Python中is和==的區(qū)別

    一文搞懂Python中is和==的區(qū)別

    is和==都是對對象進行比較判斷作用的,但對對象比較判斷的內(nèi)容并不相同,下面來看看具體區(qū)別在哪?對Python中is和==的區(qū)別感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • Django Rest framework之權(quán)限的實現(xiàn)示例

    Django Rest framework之權(quán)限的實現(xiàn)示例

    這篇文章主要介紹了Django Rest framework之權(quán)限的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • 基于Python實現(xiàn)牛牛套圈小游戲的示例代碼

    基于Python實現(xiàn)牛牛套圈小游戲的示例代碼

    “幸運牛牛套圈圈”套住歡樂,圈住幸福,等你來挑戰(zhàn)!這篇文章小編主要為大家介紹一款基于Python實現(xiàn)牛牛套圈小游戲,感興趣的小伙伴可以了解一下
    2023-02-02
  • python爬蟲scrapy框架之增量式爬蟲的示例代碼

    python爬蟲scrapy框架之增量式爬蟲的示例代碼

    這篇文章主要介紹了python爬蟲scrapy框架之增量式爬蟲的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • Python中的迭代器詳解

    Python中的迭代器詳解

    這篇文章主要介紹迭代器,看完文章你可以了解到什么是可迭代對象、啥是迭代器、如何自定義迭代器、使用迭代器的優(yōu)勢,文中有詳細的代碼示例,需要的朋友可以參考下
    2023-08-08
  • 利用Python為iOS10生成圖標和截屏

    利用Python為iOS10生成圖標和截屏

    這篇文章主要為大家詳細介紹了利用Python為iOS10生成圖標和截屏的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評論