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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • months_between的使用

    months_between的使用months_between用于计算两个日期之间相差的月数语法:months_between(date1,date2)举例a20210201与20210301selectmonths_bet

    2022年6月30日
    26
  • oracle未明确定义列[通俗易懂]

    oracle未明确定义列[通俗易懂]分类:SQL使用技巧2012-04-0616:121332人阅读评论(0)收藏举报运行环境:Oracle10gsqlplus环境下。 在查询语句中,经常会出现一个错误: SQL基础:ORA-00918:未明确定义列的错误。 当前遇到有两种情况。原因为:当查询语句中,查询的表(数据集)中有相同的字

    2022年10月5日
    2
  • PHP5.6 和PHP7.0区别

    PHP5.6 和PHP7.0区别

    2021年10月15日
    38
  • 删除卡巴斯基激活码

    删除卡巴斯基激活码

    2021年7月24日
    56
  • 常用的网站后台编辑器

    常用的网站后台编辑器

    2021年11月5日
    51
  • python,java,c语言哪个好_小萌新

    python,java,c语言哪个好_小萌新大学那会也被这个问题被困惑了大半年,直到毕业拿了几个大厂offer才发现语言的选择也就那一回事,我猜不少人刚入门的人依然被这个问题困扰着,所以决定认真分享一波我的经历。如果你还处于大一,大二,或者刚刚入门阶段,那么我认为,语言的选择并不重要,更重要的是底层/通用基础的学习,例如数据结构,算法,计算机网络这些,因为这些语言,是存在很多相同的特性的,例如你学习了C++,后面要转Java,那么其实还是可以很快就上手的。而且,等到了差不多毕业去应聘校招的时候,其实公司并不会对语言有严格的要求,例如你要面

    2025年8月21日
    4

发表回复

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

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