python 编解码解释(unicode与 uft-8)

转自:http://www.cnblogs.com/yyxayz/p/4044528.html

中文编码问题是用中文的程序员经常头大的问题,在python下也是如此,那么应该怎么理解和解决python的编码问题呢?

我们要知道python内部使用的是unicode编码,而外部却要面对千奇百怪的各种编码,比如作为中国程序经常要面对的gbk,gb2312,utf8等,那这些编码是怎么转换成内部的unicode呢?

首先我们先看一下源代码文件中使用字符串的情况。源代码文件作为文本文件就必然是以某种编码形式存储代码的,python默认会认为源代码文件是asci编码,比如说代码中有一个变量赋值:

s1=’a’ 
print s1

python(2.x 版本)认为这个’a'就是一个asci编码的字符。在仅仅使用英文字符的情况下一切正常,但是如果用了中文,比如:

s1=’哈’ 
print s1

这个代码文件被执行时就会出错,就是编码出了问题。python默认将代码文件内容当作asci编码处理,但asci编码中不存在中文,因此抛出异常。

解决问题之道就是要让python知道文件中使用的是什么编码形式,对于中文,可以用的常见编码有utf-8,gbk和gb2312等。只需在代码文件的最前端添加如下:

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

这就是告知python我这个文件里的文本是用utf-8编码的,这样,python就会依照utf-8的编码形式解读其中的字符,然后转换成unicode编码内部处理使用。

不过,如果你在Windows控制台下运行此代码的话,虽然程序是执行了,但屏幕上打印出的却不是哈字。这是由于python编码与控制台编码的不一致造成的。Windows下控制台中的编码使用的是gbk,而在代码中使用的utf-8,python按照utf-8编码打印到gbk编码的控制台下自然就会不一致而不能打印出正确的汉字。

解决办法一个是将源代码的编码也改成gbk,也就是代码第一行改成:

# -*- coding: gbk -*-

另一种方法是保持源码文件的utf-8不变,而是在’哈’前面加个u字,也就是:

s1=u’哈’ 
print s1

这样就可以正确打印出’哈’字了。

这里的这个u表示将后面跟的字符串以unicode格式存储。python会根据代码第一行标称的utf-8编码识别代码中的汉字’哈’,然后转换成unicode对象。如果我们用type查看一下’哈’的数据类型type(‘哈’),会得到<type ‘str’>,而type(u’哈’),则会得到<type ‘unicode’>,也就是在字符前面加u就表明这是一个unicode对象,这个字会以unicode格式存在于内存中,而如果不加u,表明这仅仅是一个使用某种编码的字符串,编码格式取决于python对源码文件编码的识别,这里就是utf-8。

Python在向控制台输出unicode对象的时候会自动根据输出环境的编码进行转换,但如果输出的不是unicode对象而是普通字符串,则会直接按照字符串的编码输出字符串,从而出现上面的现象。

使用unicode对象的话,除了这样使用u标记,还可以使用unicode类以及字符串的encode和decode方法。

unicode类的构造函数接受一个字符串参数和一个编码参数,将字符串封装为一个unicode,比如在这里,由于我们用的是utf-8编码,所以unicode中的编码参数使用’utf-8′将字符封装为

unicode对象,然后正确输出到控制台:

s1=unicode(‘哈’, ‘utf-8′) 
print s1

另外,用decode函数也可以将一个普通字符串转换为unicode对象。很多人都搞不明白python字符串的decode和encode函数都是什么意思。这里简要说明一下。

decode是将普通字符串按照参数中的编码格式进行解析,然后生成对应的unicode对象,比如在这里我们代码用的是utf-8,那么把一个字符串转换为unicode就是如下形式:

s2=’哈’.decode(‘utf-8′)

这时,s2就是一个存储了’哈’字的unicode对象,其实就和unicode(‘哈’, ‘utf-8′)以及u’哈’是相同的。

那么encode正好就是相反的功能,是将一个unicode对象转换为参数中编码格式的普通字符,比如下面代码:

s3=unicode(‘哈’, ‘utf-8′).encode(‘utf-8′)

s3现在又变回了utf-8的’哈’。

### 回答1: UTF-8是一种针对Unicode字符集进行编码的可变长度字符编码方案。它可以用来表示Unicode字符集中的任意字符,包括各种文字、符号和控制字符。UTF-8的编码长度根据字符的Unicode编码值的大小而变化,对于ASCII字符,UTF-8编码与ASCII相同,只需要一个字节表示;对于其他Unicode字符,UTF-8编码需要2到4个字节不等。 Unicode是一种字符集标准,它旨在为世界上所有的字符提供一个唯一的标识符,无论是汉字、拉丁字母、希腊字母、数学符号还是其他任何字符,都可以在Unicode中找到对应的编码。Unicode编码使用一种唯一的数字来表示每个字符,并通过使用不同的转换格式(如UTF-8、UTF-16等)将其存储或传输。 C是一种编程语言,可用于开发各种应用程序。在C语言中,可以使用UTF-8编码来处理Unicode字符集。C语言提供了一些处理字符串和字符的库函数,这些函数支持使用Unicode字符集进行字符串操作。通过使用适当的输入输出函数和字符处理函数,C语言可以处理包含Unicode字符的文本数据。 因此,UTF-8、Unicode和C之间存在着密切的联系。UTF-8用于编码Unicode字符集,而C语言提供了处理Unicode字符集的库函数。使用UTF-8编码的Unicode字符集,可以在C语言中进行处理和操作。这为开发人员提供了在C语言中处理多语言文本数据的能力,使得开发国际化应用程序变得更加简便。 ### 回答2: UTF-8是一种以字节为单位对 Unicode 进行编码的字符编码标准。它是一种全球通用的编码方式,能够表示几乎所有语言的字符。UTF-8采用可变长度的编码方式,用1至4个字节来表示一个字符。对于英文字符来说,UTF-8使用1个字节进行编码,而对于其他字符(例如汉字)则需要2至4个字节。由于UTF-8编码的字节数不固定,这也是它比其他编码方式更被广泛使用的主要原因之一。 Unicode是一种字符集标准,它定义了世界上几乎所有的字符和符号,并为它们分配了唯一的标识码,即码点。Unicode标准中包括了超过130万个字符,从最常见的拉丁字母到各种符号、表意文字和表情符号等。Unicode采用的是固定长度的编码方式,其中最常用的是UTF-16和UTF-8。 C语言中,通常使用utf-8编码来存储和处理字符串。由于UTF-8是一种基于字节的编码方式,它与C语言中的字符类型(char)能够相互兼容。在C语言中,可以使用char类型的数组来表示和处理UTF-8编码的字符串,同时也可以使用多字节字符集的函数库来处理UTF-8字符串。 总之,UTF-8是一种按字节编码的 Unicode 字符编码标准,它能够表示全球范围内几乎所有语言的字符。而Unicode是一个字符集标准,用于定义和标识世界上几乎所有的字符和符号。在C语言中,通常使用UTF-8编码来处理和存储字符串。 ### 回答3: UTF-8与Unicode是两种不同的字符编码方式,而C是一种计算机程序设计语言。 UTF-8(Universal Character Set Transformation Format-8)是一种可变长编码的Unicode字符编码方式。它可以用于表示Unicode字符集中的所有字符,包括拉丁字母、中日韩文字等。UTF-8编码使用1至4个字节表示不同的字符,具有较好的兼容性和可变长度特性,使得它在互联网传输中广泛应用。 Unicode是一种字符集标准,它为世界上几乎所有的字符都分配了一个唯一的数字。Unicode的目的是为了实现全球化的字符表示,使得不同国家的字符都能够得到统一的编码。 C是一种广泛应用于系统软件开发和嵌入式系统的高级程序设计语言。它是一种通用的、结构化的、面向过程的编程语言,具有高效、强大和灵活的特点。C语言原生支持ASCII编码,但对于使用UTF-8或Unicode编码的字符,可以使用转义序列来表示。 总结起来,UTF-8是一种编码方式,用于表示Unicode字符集中的字符,而C语言是一种程序设计语言,用于编写计算机程序。在C语言中,可以使用转义序列来处理UTF-8或Unicode编码的字符。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值