1. 编码和解码的概念:
    编码是将源对象内容按照一种标准转换为一种标准格式内容。
    解码是和编码对应的,它使用和编码相同的标准将编码内容还原为最初的对象内容。

2. python中的编码和解码:

  (1)decode的作用是将其他编码的字符串转换成unicode编码。

  (2)encode的作用是将unicode编码转换成其他编码的字符串。如果待编码的字符串不是Unicode,python会进行以下两步:

      a) 将字符串转换为解码为Unicode(采用python默认的编码:ASCII)

      b) 将Unicode编码为指定的编码

 3. 文件的编码格式的作用?
     文件的编码格式决定了源文件字符串的编码格式

  当文件中的字符串没有指定编码方式时,则采用“文件的编码格式”

    当文件中的字符串指定了编码方式,则使用指定的编码方式。例如:u"哈"的编码方式为Unicode不管是在GBK文件中,还是UTF-8文件中

4. python文件中,编码声明的作用?

a. 声明源文件中将出现非ascii编码,通常也就是中文;

b. 在高级的IDE中,IDE会将你的文件格式保存成你指定编码格式

c. 决定源码中类似于u'哈'(unicode)这类声明的将‘哈’解码成unicode所用的编码格式,也是一个比较容易让人迷惑的地方

5. python默认的编码格式

  python默认的编码方式为ASCII

6. 操作系统默认的编码格式

  win7 32位系统,默认的编码方式是GBK

7. 经常出现的问题:

  (1).  【代码和运行结果】:

      文件的编码格式:UTF-8(无BOM编码)

    【编码解读】:

      1). 文件的编辑格式:决定了文件中所有字符的编码----UTF-8(无BOM编码)

       故“试图打印中文”会用UTF-8进行编码\xE8\xAF\x95\xE5\x9B\xBE\xE6\x89\x93\xE5\x8D\xB0\xE4\xB8\xAD\xE6\x96\x87

      2). python默认采用的编码方式为ASCII

        python会用ASCII码对“试图打印中文”进行解码。两种编码方式不一样,故会报错

    【修改方法】:

      1). 在python文件中,加入编码声明: --------此时声明只能声明文件中会出现非ASCII编码,即中文编码

        #-*- coding:utf-8 -*-

  (2).  【代码和运行结果】:

文件的编码格式:UTF-8(无BOM编码)

      

    【编码解读】:

             1). 文件的编辑格式:决定了文件中所有字符的编码----UTF-8(无BOM编码)

       故“哈哈”会用UTF-8进行编码\xE5\x93\x88\xE5\x93\x88  

      2). print语句它的实现是将要输出的内容传送了操作系统,操作系统会根据系统的编码对输入的字节流进行编码-----win7 32位操作系统的编码为GBK

        故“\xE5\x93\x88\xE5\x93\x88”用GBK解码成了“鍝堝搱”

    【修改方法】:

      1). 将文件的编码格式修改为GBK(或者GB2312)

  (3).  【代码和运行结果】:

文件的编码格式:UTF-8(无BOM编码)

     

    【编码解读】:

             1). 文件的编辑格式:决定了文件中所有字符的编码----UTF-8(无BOM编码)

       故“哈哈”会用UTF-8进行编码\xE5\x93\x88\xE5\x93\x88

      2). encode直接编码的方法会进行如下两步操作:

        将Str解码成Unicode(采用python系统默认的编码方式ASCII)------故此步会报错

        将Unicode编码成GBK

    【修改方法】:

      1). 将python系统的默认编码方式修改为UTF-8

import sys

reload(sys)

sys.setdefaultencoding('utf-8')

      2). 先对str进行解码,解码成Unicode编码格式,后将Unicode编码格式编码成GBK

       str = str.decode("utf-8")
          str = str.encode("gbk")

  (4).  【代码和运行结果】:

文件的编码格式:UTF-8(无BOM编码)

      

    【编码解读】:

             1). 文件的编辑格式:决定了文件中所有字符的编码----UTF-8(无BOM编码)

       故“哈哈”会用UTF-8进行编码\xE5\x93\x88\xE5\x93\x88

      2). str = u"哈哈",转换成Unicode时,不是用文件的编码格式(UTF-8)进行的解码,而是用文件编码声明进行解码(GBK),这样导致出现错误  

    【修改方法】:

      1. 将文件编码声明为:

        #-*- coding:utf-8 -*-

8. 主要参考:

      (1)http://blog.csdn.net/kiki113/article/details/4062063

      (2)UTF-8、GBK、Unicoded编码对照表

      

python_中文乱码问题的更多相关文章

  1. java中文乱码解决之道(一)-----认识字符集

    沉寂了许久(大概有三个多月了吧),LZ"按捺不住"开始写博了! java编码中的中文问题是一个老生常谈的问题了,每次遇到中文乱码LZ要么是按照以前的经验修改,要么则是baidu.c ...

  2. MAC下 mysql不能插入中文和中文乱码的问题总结

    MAC下 mysql不能插入中文和中文乱码的问题总结 前言 本文中所提到的问题解决方案,都是基于mac环境下的,但其他环境,比如windows应该也适用. 问题描述 本文解决下边两个问题: 往mysq ...

  3. java中文乱码解决之道(九)-----总结

    乱码,我们前台展示的杀手,可能有些朋友和我的经历一样:遇到乱码先按照自己的经验来解决,如果没有解决就google,运气好一搜就可以解决,运气不好可能够你折腾一番了.LZ之所以写这个系列博客就是因为遇到 ...

  4. 解决springmvc+mybatis+mysql中文乱码问题【转】

    这篇文章主要介绍了解决java中springmvc+mybatis+mysql中文乱码问题的相关资料,需要的朋友可以参考下 近日使用ajax请求springmvc后台查询mysql数据库,页面显示中文 ...

  5. freemarker页面中文乱码

    一.前言 简单的记录freemarker遇到的错误问题:ftl页面中文乱码 由于freemarker整合在ssm框架中,所以笔者直接贴配置代码 <beans xmlns="http:/ ...

  6. tomcat项目中文乱码问题解决方法

    在部署tomcat项目时经常会遇到中文乱码问题,解决的方法可参考以下步骤. 1.更改Tomcat安装目录下的conf\server.xml,指定浏览器的编码格式为"utf-8"格式 ...

  7. IE下get传中文乱码的问题 -- 解决方案 (js)

    W3school 函数 JavaScript 全局对象 定义和用法 encodeURI() 函数可把字符串作为 URI 进行编码. 语法 encodeURI(URIstring) 参数 描述 URIs ...

  8. JSP和Servlet的中文乱码处理

    JSP和Servlet的中文乱码处理 前几天学习了JSP和Servlet中有关中文乱码的一些问题,写成了博客,今天进行更新一下.应该是可以解决日常的乱码问题了.现在作以下总结希望对需要的人有所帮助.我 ...

  9. Git bash下中文乱码问题

    Git bash下中文乱码--解决方案 解决办法1: 在git bash下,右键 出现下图,选择options: 选择"Text" 将Character set设置为 UTF-8 ...

随机推荐

  1. Solr学习笔记之1、环境搭建

    Solr学习笔记之1.环境搭建 一.下载相关安装包 1.JDK 2.Tomcat 3.Solr 此文所用软件包版本如下: 操作系统:Win7 64位 JDK:jdk-7u25-windows-i586 ...

  2. switch parser.p4源码

    /* Copyright 2013-present Barefoot Networks, Inc. Licensed under the Apache License, Version 2.0 (th ...

  3. PHP 开发 APP 接口 学习笔记与总结 - 静态缓存

    存储静态缓存即把缓存写入文件. file.php <?php class Cache{ //静态缓存文件后缀名 const EXT = 'txt'; //定义缓存文件存放路径 private $ ...

  4. MZhong's Resume

    MATTHEW.ZHONG Male,27 Age Front-End Developer matthew.zhong@morningstar.com OBJECTIVE My objective i ...

  5. 20145235 《Java程序设计》第一次实验报告

    实验一Java开发环境的熟悉 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Java程序. 实验知识点 1.JVM.JRE.JDK的安装位置与区 ...

  6. VSS 访问问题

    局域网同一网段的2台电脑,防火墙都是关闭的 A能ping通B 但A在运行输入B的IP地址 不能访问 求解答 1.确认输入的地址格式没有写错,例如B的IP地址为:192.168.1.20.那么在A电脑的 ...

  7. Memcache 提高缓存命中率

    最近手上某个项目跟新代码,新的代码里大量采用memcahce作为缓存.所以开始深入了解memcache的内存分配策略.以前就听说有个PHP写的memcache监控脚本,在网上搜索了一下,果断下载下来用 ...

  8. javaWeb中struts开发——Logic标签

    1.Struts标签的logic标签 Logic标签是逻辑标签,是Struts中比较重要的标签,完成各种逻辑运算操作,可以直接支持全局调转. 2.1<logic:present><l ...

  9. 转载:C++线程池的一个实现

    原文转自:http://www.cnblogs.com/lidabo/p/3328646.html 略有修改 Cthread类参见:http://www.cnblogs.com/tangxin-blo ...

  10. Nodejs电影建站开发实例(下)

    作为一个真正的网站,不能没有数据的支持,下面使用的数据库为mongodb,电影可能有的数据:电影名称.导演.国家.语言.上映时间.图片.简介.视频 4.使用路由 app.js var express ...