一、概念介绍

1.1 读写模式

文件操作的基础模式有三种,默认的操作模式(也就是不指定模式时)为r模式:

  • r模式为read:只读
  • w模式为write:只写
  • a模式为append:追加

1.2 内容格式

文件读写内容的格式有两种(默认的读写内容的模式为b模式):

  • t模式为text:文本格式
  • b模式为bytes:字节格式

需要注意的是:t、b这两种模式均不能单独使用,都需要与r/w/a之一连用

二、文件的打开模式之r模式

r: read,只读模式,只能读不能写,文件不存在时报错。

f = open(\'32.txt\', mode=\'r\')  # 报错
f.write()
f.close()


# rt: read by text
# windows的操作系统默认编码为gbk,因此需要使用utf8编码
f = open(\'32.txt\', mode=\'rt\', encoding=\'utf8\')
data = f.read()
print(data)
print(f"type(data): {type(data)}")
f.close()

# aaa
# bbb
# ccc
# type(data): <class \'str\'>


# rb: read by bytes
f = open(\'32.txt\', mode=\'rb\')
data = f.read()
print(data)
print(f"type(data): {type(data)}")
f.close()

#b\'aaa\nbbb\nccc\nnick\xe6\x9c\x80\xe5\xb8\x85\xe5\x90\x97\'
type(data): <class \'bytes\'>

f.read()读取完文件后,文件指针会跑到文件的末端,如果再一次读取,读取的将是空。

f = open(\'32.txt\', mode=\'rt\', encoding=\'utf8\')
data1 = f.read()
data2 = f.read()
print(f"data1: {data1}")
print(f"data2: {data2}")
f.close()

#data1: aaa
# bbb
# ccc
# data2: 

缺点:由于f.read()一次性读取文件的所有内容,如果文件非常大的话,可能会造成内存爆掉,即电脑卡死。因此可以使用f.readline()/f.readlines()读取文件内容。

# f.readline()/f.readlines()
f = open(\'32.txt\', mode=\'rt\', encoding=\'utf8\')
print(f"f.readable(): {f.readable()}")  # 判断文件是否可读
data1 = f.readline()
data2 = f.readlines()
print(f"data1: {data1}")
print(f"data2: {data2}")
f.close()

# f.readable(): True
# data1: aaa
# data2: [\'bbb\n\', \'ccc\n\']

三、文件打开模式之w模式

w: 只能写,不能读,文件存在的时候回清空文件后再写入内容;文件不存在的时候会创建文件后写入内容。

# wt
f = open(\'34w.txt\', mode=\'wt\', encoding=\'utf8\')
print(f"f.readable(): {f.readable()}")
f.write(\'lwx 真帅呀\n\')  # \'\n\'是换行符
f.write(\'lwx,lwx, you drop, I drop.\')
f.write(\'lwx 帅的我五体投地\')
f.flush()  # 立刻将文件内容从内存刷到硬盘
f.close()

#f.readable(): False


# wb
f = open(\'34a.txt\', mode=\'wb\')
f.write(\'lwx 帅的我五体投地\'.encode(\'unicode_escape\'))  # 编码成bytes类型
print(
    f"type(\'lwx 帅的我五体投地\'.encode(\'unicode_escape\')): {type(\'lwx 帅的我五体投地\'.encode(\'unicode_escape\'))}")
f.close()


#type(\'lwx 帅的我五体投地\'.encode(\'unicode_escape\')): <class \'bytes\'>

四、文件打开模式之a模式

a: 可以追加。文件存在,则在文件的末端写入内容;文件不存在的时候会创建文件后写入内容

# at
f = open(\'34a.txt\', mode=\'at\', encoding=\'utf8\')
print(f"f.readable(): {f.readable()}")
f.write(\'lwx 真帅呀\n\')  # \'\n\'是换行符
f.write(\'lwx,lwx, you drop, I drop.\')
f.write(\'lwx 帅的我五体投地\')
f.close()

#f.readable(): False

五、文件打开读取二进制

try:
    import requests

    response = requests.get(
        \'https://www.cnblogs.com/AShine/p/13517932.html\')
    data = response.content

    f = open(\'mv.jpg?x-oss-process=style/watermark\', \'wb\')
    f.write(data)
    print(\'done...\')
    f.close()
except Exception as e:
    print(e, \'报错了,那就算了吧,以后爬虫处会详细介绍\')

#done...

f = open(\'34w.txt\', \'wb\')
f.write(\'lwx 好帅啊\'.encode(\'utf8\'))
f.close()

版权声明:本文为LWX-YEER原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/LWX-YEER/p/11379558.html