标签:执行 utf8 文件句柄 句柄 read open 删除 类型 .com
对文件操作流程
f = open(‘lyrics‘,‘r‘,encoding=‘utf-8‘) read_line = f.readline()#读取一行 print(read_line) print(‘我是分割线‘.center(50,‘-‘)) data = f.read()#读取全部 print(data)
打开文件的模式有:
"+" 表示可以同时读写某个文件
"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)
"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)
with语句
为了避免打开文件后忘记关闭,可以通过管理上下文,即:
with open(‘lyrics‘,‘r‘,encoding=‘utf-8‘) as f: data = f.read() print(data)
如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。
需知:
1.在python2默认编码是ASCII, python3里默认是unicode
2.unicode 分为 utf-32(占4个字节),utf-16(占两个字节),utf-8(占1-4个字节), so utf-16就是现在最常用的unicode版本, 不过在文件里存的还是utf-8,因为utf8省空间
3.在py3中encode,在转码的同时还会把string 变成bytes类型,decode在解码的同时还会把bytes变回string
#python2 msg = "我爱北京天安门" msg_gb2312 = msg.decode("utf-8").encode("gb2312")
#python3
msg_gb2312 = msg.encode("gb2312") #默认就是unicode,不用再decode,喜大普奔
标签:执行 utf8 文件句柄 句柄 read open 删除 类型 .com
原文地址:https://www.cnblogs.com/syj888/p/10436450.html