Python程序中使用SQLAlchemy時(shí)出現(xiàn)亂碼的解決方案
今天對(duì)clubot進(jìn)行了升級(jí), 但是導(dǎo)入數(shù)據(jù)后中文亂碼, 一開是找資料說是在創(chuàng)建引擎的時(shí)候添加編碼信息:
engine = create_engine("mysql://root:@localhost:3306/clubot?charset=utf8")
但是這并不行, 然后查看表信息:
> show create table clubot_members; clubot_members | CREATE TABLE `clubot_members` ( `id` int(11) NOT NULL AUTO_INCREMENT, `email` varchar(100) DEFAULT NULL, `nick` varchar(50) DEFAULT NULL, `last_say` timestamp NULL DEFAULT NULL, `last_change` timestamp NULL DEFAULT NULL, `isonline` int(11) DEFAULT NULL, `join_date` timestamp NULL DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `email` (`email`), UNIQUE KEY `nick` (`nick`) ) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=latin1;
發(fā)現(xiàn)原來創(chuàng)建表的時(shí)候用的latin1編碼, 而老的表是用utf-8編碼創(chuàng)建的, SQLAlchemy中并沒有發(fā)現(xiàn)有創(chuàng)建表時(shí)指定指定編碼的方法. 所以只能在MySQL本身來找:
> show VARIABLES like "character%%"; +--------------------------+-----------------------------+ | Variable_name | Value | +--------------------------+-----------------------------+ | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /data/share/mysql/charsets/ | +--------------------------+-----------------------------+ 8 rows in set (0.00 sec) > show create database clubot; +----------+-------------------------------------------------------------------+ | Database | Create Database | +----------+-------------------------------------------------------------------+ | clubot | CREATE DATABASE `clubot` /*!40100 DEFAULT CHARACTER SET latin1 */ | +----------+-------------------------------------------------------------------+ 1 row in set (0.00 sec)
發(fā)現(xiàn) MySQL默認(rèn)的和數(shù)據(jù)庫都是latin1的編碼, 所以更改數(shù)據(jù)庫配置
分別在[client] [mysqld]下添加
這時(shí)重啟MySQL居然起不來, 說default-character-set是無效的變量, 查看MySQL版本發(fā)現(xiàn)是5.5, 找資料說5.5的服務(wù)端編碼設(shè)置變量是character-set-server, 所以將[mysqld]上的default-character-set = utf8改為 character-set-server = utf8, 并重啟MySQL
然后更改數(shù)據(jù)庫編碼:
刪除新建的表, 并重新導(dǎo)入數(shù)據(jù)中文就正常了
> drop table clubot_status;
> drop table clubot_infos;
> drop table clubot_history;
> drop table clubot_members;
- Python的SQLalchemy模塊連接與操作MySQL的基礎(chǔ)示例
- Python SQLAlchemy基本操作和常用技巧(包含大量實(shí)例,非常好)
- python之sqlalchemy創(chuàng)建表的實(shí)例詳解
- 淺析python中SQLAlchemy排序的一個(gè)坑
- Python SqlAlchemy動(dòng)態(tài)添加數(shù)據(jù)表字段實(shí)例解析
- Python的SQLAlchemy框架使用入門
- Python 數(shù)據(jù)庫操作 SQLAlchemy的示例代碼
- Python使用sqlalchemy模塊連接數(shù)據(jù)庫操作示例
相關(guān)文章
Python中的浮點(diǎn)數(shù)原理與運(yùn)算分析
這篇文章主要介紹了Python中的浮點(diǎn)數(shù)原理與運(yùn)算分析,結(jié)合實(shí)例形式分析了Python浮點(diǎn)數(shù)操作的常見錯(cuò)誤,并簡單解釋了浮點(diǎn)數(shù)運(yùn)算的原理與比較運(yùn)算實(shí)現(xiàn)方法,需要的朋友可以參考下2017-10-10
Python3.7.0 Shell添加清屏快捷鍵的實(shí)現(xiàn)示例
這篇文章主要介紹了Python3.7.0 Shell添加清屏快捷鍵的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
Python pandas dataframe之重命名相同列名
這篇文章主要介紹了Python pandas dataframe之重命名相同列名方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Python實(shí)現(xiàn)SICP賦值和局部狀態(tài)
這篇文章主要介紹了Python實(shí)現(xiàn)SICP 賦值和局部狀態(tài)的相關(guān)知識(shí),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
python周期任務(wù)調(diào)度工具Schedule使用詳解
這篇文章主要為大家介紹了python周期任務(wù)調(diào)度工具Schedule的使用及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-11-11
Django結(jié)合ajax進(jìn)行頁面實(shí)時(shí)更新的例子
今天小編就為大家分享一篇Django結(jié)合ajax進(jìn)行頁面實(shí)時(shí)更新的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08

