Labelme批量转换json文件(代码基础6)

本文介绍了Python中的编码与解码过程,包括字符串类型的变化、常用编码类型,以及在Python3中如何处理编码问题。通过示例展示了如何使用decode和encode方法进行字符串的转换,并讨论了文件读取时的编码问题,强调了了解文件编码格式的重要性。最后,文章探讨了ASCII、Unicode、UTF-8、GBK等字符编码格式以及字节序的概念。
摘要由CSDN通过智能技术生成

果然还是代码看得少,写得少,还是一个小白菜鸟,有高手指点发现问题比较及时。小白菜鸟继续更新中~~~~

encode和decode编码

一 基本知识点

字符串编码常用类型:utf-8,gb2312,cp936,gbk等。

python中,我们使用decode()encode()来进行解码和编码

python中,使用unicode类型作为编码的基础类型。即

     decode              encode

str ---------> unicode --------->str

u = u'中文' #显示指定unicode类型对象u

str = u.encode('gb2312') #以gb2312编码对unicode对像进行编码
str1 = u.encode('gbk') #以gbk编码对unicode对像进行编码
str2 = u.encode('utf-8') #以utf-8编码对unicode对像进行编码

u1 = str.decode('gb2312')#以gb2312编码对字符串str进行解码,以获取unicode

u2 = str.decode('utf-8')#如果以utf-8的编码对str进行解码得到的结果,将无法还原原来的unicode类型

 

如上面代码,str\str1\str2均为字符串类型(str,给字符串操作带来较大的复杂性。

好消息来了,对,那就是python3,在新版本的python3中,取消了unicode类型,代替它的是使用unicode字符的字符串类型(str),字符串类型(str)成为基础类型如下所示,而编码后的变为了字节类型(bytes)但是两个函数的使用方法不变:

     decode              encode

bytes ------> str(unicode)------>bytes

u = '中文' #指定字符串类型对象u

str = u.encode('gb2312') #以gb2312编码对u进行编码,获得bytes类型对象str

u1 = str.decode('gb2312')#以gb2312编码对字符串str进行解码,获得字符串类型对象u1

u2 = str.decode('utf-8')#如果以utf-8的编码对str进行解码得到的结果,将无法还原原来的字符串内容

避免不了的是,文件读取问题:

假如我们读取一个文件,文件保存时,使用的编码格式,决定了我们从文件读取的内容的编码格式,例如,我们从记事本新建一个文本文件test.txt, 编辑内容,保存的时候注意,编码格式是可以选择的,例如我们可以选择gb2312,那么使用python读取文件内容,方式如下:

 

f = open('test.txt','r')

s = f.read() #读取文件内容,如果是不识别的encoding格式(识别的encoding类型跟使用的系统有关),这里将读取失败

'''假设文件保存时以gb2312编码保存'''

u = s.decode('gb2312') #以文件保存格式对内容进行解码,获得unicode字符串

'''下面我们就可以对内容进行各种编码的转换了'''

str = u.encode('utf-8')#转换为utf-8编码的字符串str

str1 = u.encode('gbk')#转换为gbk编码的字符串str1

str1 = u.encode('utf-16')#转换为utf-16编码的字符串str1

 

python给我们提供了一个包codecs进行文件的读取,这个包中的open()函数可以指定编码的类型:

 

import codecs

f = codecs.open('text.text','r+',encoding='utf-8')#必须事先知道文件的编码格式,这里文件编码是使用的utf-8

content = f.read()#如果open时使用的encoding和文件本身的encoding不一致的话,那么这里将将会产生错误

f.write('你想要写入的信息'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值