web.py+mysql插入中文提示query = query.encode(charset) UnicodeEncodeError: 'latin-1' codec can't encode characters in position 86-100
2015-06-02 11:18
549 查看
对于中文编码的问题,总会出现各种各样恶心的错误,还不知道应该怎么解决,首先,你从最开头就应该关注编码问题,尽量保证所有的编码方式都是一致的
用python+web.py+mysql来写程序,首先要保证如下几个部分的编码都是对滴
主要包括如下几个部分:
1:python 写的程序, 统一用 utf-8 ,以及重新载入utf-8
2: web.py 的模板, 也就是html程序
统一保存格式为utf-8 , 并且html 申明 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
3:Mysql 建立数据库,数据库使用UTF-8(包括建数据库和建表的时候,把编码格式都使用utf8)
但最后还是会有这样的问题,错误提示如下:
[2015-06-02 10:35:38] [INFO] self.pool <DBUtils.PooledDB.PooledDB instance at 0x028E7E18>
[2015-06-02 10:35:38] [INFO] conn:
[2015-06-02 10:35:38] [INFO] <DBUtils.PooledDB.PooledDedicatedDBConnection instance at 0x02ADA580>
[2015-06-02 10:35:38] [INFO] cursor:
[2015-06-02 10:35:38] [INFO] <MySQLdb.cursors.Cursor object at 0x029EED10>
[2015-06-02 10:35:38] [ERROR] DB_execute error: Traceback (most recent call last):
File "E:\code\mid-project-2015-6-2\dailypaper\model.py", line 131, in execute
cursor.execute(sql)
File "C:\Python26\lib\site-packages\dbutils-1.1-py2.6.egg\DBUtils\SteadyDB.py", line 552, in tough_method
result = method(*args, **kwargs) # try to execute
File "C:\Python26\lib\site-packages\MySQLdb\cursors.py", line 149, in execute
query = query.encode(charset)
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 86-100: ordinal not in range(256)
然后能看到的是cursors.py里面的query = query.encode(charset),那么应该是这个charset的原因,直接把charset改成'utf-8'就行了,query = query.encode('utf-8')
然后就可以插入,并且可以select出来正确的值,然后从网页上也能够看到啦!!!
用python+web.py+mysql来写程序,首先要保证如下几个部分的编码都是对滴
主要包括如下几个部分:
1:python 写的程序, 统一用 utf-8 ,以及重新载入utf-8
2: web.py 的模板, 也就是html程序
统一保存格式为utf-8 , 并且html 申明 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
3:Mysql 建立数据库,数据库使用UTF-8(包括建数据库和建表的时候,把编码格式都使用utf8)
但最后还是会有这样的问题,错误提示如下:
[2015-06-02 10:35:38] [INFO] self.pool <DBUtils.PooledDB.PooledDB instance at 0x028E7E18>
[2015-06-02 10:35:38] [INFO] conn:
[2015-06-02 10:35:38] [INFO] <DBUtils.PooledDB.PooledDedicatedDBConnection instance at 0x02ADA580>
[2015-06-02 10:35:38] [INFO] cursor:
[2015-06-02 10:35:38] [INFO] <MySQLdb.cursors.Cursor object at 0x029EED10>
[2015-06-02 10:35:38] [ERROR] DB_execute error: Traceback (most recent call last):
File "E:\code\mid-project-2015-6-2\dailypaper\model.py", line 131, in execute
cursor.execute(sql)
File "C:\Python26\lib\site-packages\dbutils-1.1-py2.6.egg\DBUtils\SteadyDB.py", line 552, in tough_method
result = method(*args, **kwargs) # try to execute
File "C:\Python26\lib\site-packages\MySQLdb\cursors.py", line 149, in execute
query = query.encode(charset)
UnicodeEncodeError: 'latin-1' codec can't encode characters in position 86-100: ordinal not in range(256)
然后能看到的是cursors.py里面的query = query.encode(charset),那么应该是这个charset的原因,直接把charset改成'utf-8'就行了,query = query.encode('utf-8')
然后就可以插入,并且可以select出来正确的值,然后从网页上也能够看到啦!!!
相关文章推荐
- MYSQL Optimizing LIMIT Queries
- IOS开发----UIImagePickerController详细用法
- GRE Issue 范文 Topic 5
- UIKit 框架之UICollectionViewController
- dyld: Symbol not found: _OBJC_CLASS_$_UIBlurEffect
- ArrayBlockingQueue和ExecutorService的理解与感悟
- iOS学习(1)——UIButton
- 优化UITableViewCell高度计算的那些事
- 后台request获得所有参数(当你不知道它包含什么参数)
- UIImage 按照指定宽度等比例裁切
- GRE ISSUE写作论证论据素材 国家制度建设类
- UIKit 框架之UISearchController
- APUE: Ext2文件系统布局,文件数据块寻址,VFS虚拟文件系统
- poj2478 Farey Sequence(线性筛法+欧拉函数+递推)
- Arch下Android Studio下报错Cannot run program "/xx/build-tools/xx/aapt": error=2解决
- LABjs、RequireJS、SeaJS的区别
- Entity Framework:使用Fluent API配置数据表映射
- Entity Framework:IQueryable与IEnumberable的区别
- 使用Data Annotations和Fluent API配置数据库的映射
- ThreadLocal 与 Request 和 Session 之关联