python codecs_python中转换模块codecs的讲解(附示例)

python codecs_python中转换模块codecs的讲解(附示例)本篇文章给大家带来的内容是关于 python 中转换模块 codecs 的讲解 附示例 有一定的参考价值 有需要的朋友可以参考一下 希望对你有所帮助 0 编码编码转换时 通常需要以 unicode 作为中间编码 即先将其他编码的字符串解码 decode 成 unicode 再从 unicode 编码 encode 成另一种编码 str1 decode gb2312 将 gb2312 编码的字符串转换成 u

本篇文章给大家带来的内容是关于python中转换模块codecs的讲解(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

0、编码

编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码。str1.decode(‘gb2312’) #将gb2312编码的字符串转换成unicode编码

str2.encode(‘gb2312’) #将unicode编码的字符串转换成gb2312编码

注意事项:

s=‘中文’ 如果是在utf8的文件中,该字符串就是utf8编码,如果是在gb2312的文件中,则其编码为gb2312。这种情况下,要进行编码转换,都需要先用decode方法将其转换成unicode编码,再使用encode方法将其转换成其他编码。

在没有指定特定的编码方式时,都是使用的系统默认编码创建的代码文件。

如果字符串是这样定义: s=u’中文’ 则该字符串的编码就被指定为unicode了,即python的内部编码,而与代码文件本身的编码无关。只需要直接使用encode方法将其转换成指定编码即可

如果一个字符串已经是unicode了,再进行解码则将出错,因此通常要对其编码方式是否为unicode进行判断isinstance(s, unicode) #用来判断是否为unicode

1、查看编码方式

(1)对于我们经常使用的记事本,“文件” -> “另存为”,可查看到当前的编码方式。

(2)用notepad++打开,点击“菜单栏” -> “格式”可以查看到。

(3)UltraEdit:

不同编码的文本,是根据文本的前两个字节来定义其编码格式的,定义如下:

ANSI:        无格式定义;

Unicode:       前两个字节为FFFE;

Unicode big endian: 前两字节为FEFF;

UTF-8:        前两字节为EFBB;

这样通过前面两个字节就可以判定出文件的具体格式了。

2、python编码

当python要做编码转换的时候,会借助于内部的编码,转换过程是这样的:

原有编码 -> 内部编码 -> 目的编码

python的内部是使用unicode来处理的,但是unicode的使用需要考虑的是它的编码格式有两种,一是UCS-2,它一共有65536个码位,另一种是UCS-4,它有g个码位。

判断安装的python是用什么编码方式:import sys

print(sys.maxunicode)

如果输出的值为65535,那么就是UCS-2,如果输出是就是UCS-4编码。

转换成内部码:c = “风卷残云”

print(type(c))

c = bytes(c,encoding=’utf-8′)

print(type(c))

print(c)

b = codecs.decode(c, “utf-8”) #与c.decode()等效

print(type(b))

print(b)

print(c.decode())

输出:

b’\xe9\xa3\x8e\xe5\x8d\xb7\xe6\xae\x8b\xe4\xba\x91′

风卷残云

风卷残云

3、codecs模块

codecs专门用作编码转换。通过它的接口是可以扩展到其他关于代码方面的转换。

在python3.x中可以直接将bytes类型的数据转换成其他编码格式,而不用手动先转成unicode。import codecs

a = “我爱你”

# 创建utf-8编码器

look = codecs.lookup(‘utf-8’)

type(a)

a = bytes(a,encoding=’utf-8′)

b = look.decode(a)

print(b)

输出:(‘我爱你’, 9)

返回的元组中b[0]是数据,b[1]是长度。

用codecs提供的open方法来指定打开的文件的语言编码,它会在读取的时候自动转换为内部unicodef = codecs.open(filepath, ‘r’, ‘utf8’)

读取方式有很多种,这里的f是可以用for循环遍历的,当然也可以直接用readline或者readlines函数方法来读取。#for i in f:

# print(i)

#f.readline()

#f.read()

#f.readlines()

以上就是python中转换模块codecs的讲解(附示例)的详细内容,更多请关注php中文网其它相关文章!

article_wechat2021.jpg?1111

本文转载于:CSDN,如有侵犯,请联系删除

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233499.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • css画圆弧_css圆角样式

    css画圆弧_css圆角样式CSS3是样式表(stylesheet)语言的最新版本,它的一大优点就是支持圆角。网页设计大师NicholasZakas的最新文章,清晰易懂地解释了CSS3圆角的各个方面,非常值得学习。以下就是我翻译的中文版。=========================================CSS3圆角详解作者:NicholasZakas译者:阮一峰发表日期:2010年12月8日一、CSS3…

    2025年7月25日
    0
  • 1123581321递归算法_线性递归数列例题

    1123581321递归算法_线性递归数列例题[BZOJ3231][Sdoi2008]递归数列题目大意给定Ci,i∈[1,k]给定C_i,i\in[1,k]定义若i>k,Ai=Ai−1∗C1+Ai−2∗C2+⋯+Ai−k∗Ck若i>k,A_i=A_{i-1}*C_1+A_{i-2}*C_2+\cdots+A_{i-k}*C_k否则Ai=Bi否则A_i=B_i询问sum(A)n−sum(A)m−1询问sum(A)_n-sum(A

    2022年9月12日
    0
  • Python Flow control[通俗易懂]

    Python Flow control[通俗易懂]HowtotellPythontomakeintelligentdecisionsaboutwhatcodetorun,whatcodetoskip,andwhatcodetorepeatbasedonthevaluesithas.WithFlowcharts!Flowcontrolwillneedyesornooptionstomakedecisions.InPythoncode,yesandnoisshownas

    2022年5月29日
    32
  • 网易ubuntu软件源_ubuntu如何更新源

    网易ubuntu软件源_ubuntu如何更新源ubuntu各版本网易源

    2022年8月31日
    1
  • Andriod TV开发之Leanback

    Andriod TV开发之Leanback2019 独角兽企业重金招聘 Python 工程师标准 gt gt gt

    2025年6月13日
    0
  • Windows Azure AppFabric应用程序

    Windows Azure AppFabric应用程序WindowsAzureAppFabric团队在大步前进。在上个月发布服务总线队列和Topics到CTP之后,这个团队刚刚发布AppFabric应用程序到CTP。AppFabric应用程序简化了将服务组成一个应用程序的任务,但实际上,它似乎重写了平台作为服务的意义(PaaS)

    2022年10月16日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号