python IO(读取、写入文件内容)总结

1、打开桌面的一个txt文件,并显示里面的内容

# f = open(r'C:Users\TEST\Desktop\tmp2.txt','r',encoding='utf-8',errors='ignore')
f = open('C:Users/TEST/Desktop/tmp2.txt','r',encoding='utf-8',errors='ignore')
fr = f.read()
print(fr)
f.close()

解释说明:
针对windows系统,第一行和第二行,这两种方式都适用。以‘r’只读的方式,并且以utf-8的编码(支持中文)打开文件,如果有不能识别的编码就忽略,最后需要用f.close()关闭文件。

以上代码作用等同于:

with open('C:Users/TEST/Desktop/tmp2.txt','r',encoding='utf-8',errors='ignore') as f:
    print(f.read())
  • 如果文件内容过多,会占用很多内存,可以设定读取多少字节的内容,例如:
with open('C:Users/TEST/Desktop/tmp2.txt','r',encoding='utf-8') as f:
    print(f.read(2))

解释说明:
以上代码会读取文件的前2个字节,测试结果为,会读取2个中文字符或者2个英文字符,按理说,utf-8编码中,中文字符占3个字节或者4个字节,不知道为什么和这里有冲突?

  • 每次读取文件的一行内容,代码如下:
with open('C:Users/TEST/Desktop/tmp2.txt','r',encoding='utf-8') as f:
    for line in f.readlines():
        print(line)
  • 要读取视频或者图片,代码如下:
with open('C:Users/TEST/Desktop/test2.png','rb') as f:
    print(f.read())

输出结果是一串十六进制表示的字节:

b’\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00~\x00\x00\x00`\x08\x02\x00\x00\x00T\x9dQ4\x00\x00\x01BIDATx\x01\xed\xd2A\r\x00…

2、写入文件

f = open('C:/Users/TEST/Desktop/tmp.txt','w',encoding='utf-8')
f.write('just a test')
f.close()

或者:

with open('C:/Users/TEST/Desktop/tmp.txt','w',encoding='utf-8') as f:
    f.write('just a test')

解释说明:
w是写入,wb是以二进制(用于保存图片或视频)的方式写入,a是追加,用于在文件原有内容的后边添加新内容,而不是覆盖原有内容。

你可能感兴趣的:(python学习,学习总结)