-------------------------------------------------------------------------
文件打开方式
---------------------------------------------------------------------------
r 打开只读文件,该文件必须存在。
r+具有读写属性,从文件头开始写,保留原文件中没有被覆盖的内容,文件必须存在;
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+具有读写属性,写的时候如果文件存在,会被清空,从头开始写,如文件不存在则创建该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。
w+与r+区别:r+:可读可写,若文件不存在,报错;w+: 可读可写,若文件不存在,创建
r+与a+区别:r+,可读写,文件必须文件,从文件开头开始写;a+,可读写,文件存在则在文件末尾追加写;文件不存在则创建文件
更全面的读写模式总结如下:
模式 | 描述 |
---|---|
r | 打开一个文件为只读。文件指针置于该文件的开头。这是默认模式。 |
rb | 打开一个文件只能以二进制格式读取。文件指针置于该文件的开头。这是默认模式。 |
r+ | 打开用于读取和写入文件。文件指针将会在文件的开头。 |
rb+ | 打开用于读取和写入二进制格式的文件。文件指针将会在文件的开头。 |
w | 打开一个文件只写。覆盖该文件,如果该文件存在。如果该文件不存在,则创建用于写入一个新的文件。 |
wb | 打开一个文件只能以二进制格式写入。覆盖该文件,如果该文件存在。如果该文件不存在,则创建用于写入一个新的文件。 |
w+ | 打开用于写入和读取的文件。覆盖现有的文件,如果文件存在。如果该文件不存在,则创建读取和写入新的文件。 |
wb+ | 打开用于写入和读取的二进制格式的文件。覆盖现有的文件,如果文件存在。如果该文件不存在,则创建读取和写入新的文件。 |
a | 将打开追加文件。文件指针是在文件的结尾。也就是说,该文件是在附加模式。如果该文件不存在,它创造了写入一个新的文件。 |
ab | 将打开追加的二进制格式的文件。文件指针在该文件的结束。也就是说,该文件为追加模式。如果该文件不存在,它创建并写入一个新的文件。 |
a+ | 打开为追加和读取文件。文件指针在该文件的结束。该文件将为追加模式。如果该文件不存在,它创建并读取和写入的新文件。 |
ab+ | 打开两个追加和读取的二进制格式的文件。文件指针在该文件的结束。该文件将在追加模式。如果该文件不存在,它创建并读取和写入的新文件。 |
>>> fd=open("1.txt","w+") #以w+方式发开文件,文件不存在则创建,文件存在清空
>>> fd.write("123\n456\nabc\n") #写入字符串"123\n456\nabc\n"共12字符
12
>>> fd.flush() #将写入缓存中的内容写进磁盘,此时手动打开文件1.txt可看到文件内容
>>> fd.read() #文件指针此时在文件末尾,read的时候是从当前指针位置开始读,所以读不到内容
''
>>> fd.tell() #检查当前指针的位置,文件末尾有个EOF
15
>>> fd.seek(0) #将文件指针指向文件开头
0
>>> fd.read() #这个时候就可以读到文件内容了
'123\n456\nabc\n'
>>> fd.read() #现在文件指针又移到文件末尾了,所以读不到内容
''
>>> fd=open("1.txt","r+") #以r+形式打开文件,文件必须存在,文件指针在文件的开头,写的时候文件从文件开头写入并且会覆盖相同长度的内容
>>> fd.tell() #通过tell()可以查看当前文件指针的位置,0表示在文件的开头
0
>>> fd.write("xxx\n") #在文件开头写入xxx
4
>>> fd.tell()
5
>>> fd.seek(0)
0
>>> fd.read() ##读取文件内容,可以看出在确实是在文件的开头写入的xxx,并覆盖了123,说明r+进行了覆盖写操作
'xxx\n456\nabc\n'
以 'U' 标志打开文件, 所有的行分割符通过 Python 的输入方法(例#如 read*() ),返回时都会被替换为换行符\n. ('rU' 模式也支持 'rb' 选项) .
r和U要求文件必须存在
不可读的打开方式:w和a
若不存在会创建新文件的打开方式:a,a+,w,w+
---------------------------------------------------
常见文件操作方法
----------------------------------------------------
seek():指定指针的位置
tell():获取指针当前位置
read([size]):读取文件所有内容
readline([size]):每次读一行,
readlines([size]):读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。
truncate([size]):截取文件,使文件大小为size
flush():刷新输出缓存
close():关闭打开的文件,将缓存写入磁盘文件
需要注意的是:由于缓冲,字符串可能实际上没有出现在该文件中,直到调用flush()或close()方法被调用.
一般的文件流操作都包含缓冲机制,write方法并不直接将数据写入文件,而是先写入内存中特定的缓冲区。
flush方法是用来刷新缓冲区的,即将缓冲区中的数据立刻写入文件,同时清空缓冲区。
正常情况下缓冲区满时,操作系统会自动将缓冲数据写入到文件中。
至于close方法,原理是内部先调用flush方法来刷新缓冲区,再执行关闭操作,这样即使缓冲区数据未满也能保证数据的完整性。
如果进程意外退出或正常退出时而未执行文件的close方法,缓冲区中的内容将会丢失。
-----------------------------------
多文件打开方式
------------------------------------
with open('ha.log','r',encoding='utf-8') as f1 , open('ha1.log','a',encoding='utf-8') as f2: for line in f1:#循环f1 逐行获取f1的内容 f2.write(line)#这样就将ha.log文件的内容 复制到f2中