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
是追加,用于在文件原有内容的后边添加新内容,而不是覆盖原有内容。