文件對象的讀寫操作
-
文件的讀寫操作
文件模式 操作 r 以讀方式打開 w 以寫的方式打開(必要時清空) a 以追加的模式打開(必要時創(chuàng)建新文件) r+ 以讀寫模式打開 w+ 以讀寫模式打開 a+ 以讀寫模式打開 rb 以二進(jìn)制讀模式打開 wb 以二進(jìn)制寫模式打開 ab 以二進(jìn)制追加模式打開 rb+ 以二進(jìn)制讀寫模式打開 wb+ 以二進(jìn)制讀寫模式打開 ab+ 以二進(jìn)制讀寫模式打開 -
w+、r+的區(qū)別
- r+:可讀可寫,若文件不存在,報錯;
- w+:可讀可寫,若文件不存在,創(chuàng)建;
-
a、a+、w、w+
- a、w打開文件沒有讀取功能;
- a、a+、w、w+若不存在會創(chuàng)建新文件;
- a:附加寫方式打開;a+:附加讀寫方式打開;
-
文件的寫
- 寫需要注意訪問模式,到底操作的是字節(jié)還是字符
- 路徑如果不指定,默認(rèn)與python解析器的路徑一致
- 文件的分類
- 純文本(解碼utf-8,w)
- 非純文本(二進(jìn)制字節(jié),wb)
- 如果文件不存在,新建.如果文件存在,清空原來的內(nèi)容,再寫入新的內(nèi)容.
-
文件的讀
- f.read():----->讀取文件里面所有的內(nèi)容,并返回
- readlines(n):------->一次讀取文件的全部內(nèi)容,并按行放回list
- readline(n):------>最多讀取n個字節(jié)的內(nèi)容(也是一行一行的讀)
- flush:----------->將內(nèi)存的東西刷到硬盤中
文件夾操作的時候w模式會覆蓋原來的文件(因此原來的文件會消失,要特別注意);文件操作的時候w、w+模式寫入的內(nèi)容會覆蓋原來的內(nèi)容,也要特別注意
-
打開文件格式
-
f=open('路徑/文件名', '讀寫格式', '編碼方式', '錯誤處理方式')
- 打開文件之后必須要執(zhí)行關(guān)閉文件的操作
- eg:f=open('/Users/noiccy/Desktop/PythonCode/test.txt','r', encoding='UTF-8', errors='ignore')
- 使用with語句,python可以自動調(diào)用close()方法
-
f=open('路徑/文件名', '讀寫格式', '編碼方式', '錯誤處理方式')
-
常見文件對象方法
文件對象方法 操作 file.close() 關(guān)閉文件 file.flush() 刷新文件的內(nèi)存緩沖區(qū) file.read(size=-1) 讀取文件的內(nèi)容,可以指定讀取的長度;如果長度小于1,讀取文件全部的內(nèi)容 file.readline(size=-1) 從文件中讀取并返回一行;一般模式下是一行一行的讀取,換行符單獨(dú)算一行 file.readlines(sizhint=0) 讀取文件的所有行為作為一個列表返回(包含所有的行結(jié)束符):如果給定sizhint且大于0,那么將返回總和大約為sizhint字節(jié)的行 file.wirte(str) 寫入文件,返回當(dāng)前在文件中的位置 file.writelines(seq) 向文件寫入字符串序列seq:seq應(yīng)該是一個返回字符串的可迭代對象 file.next() 返回文件的下一行(類似于file.readline()),或在沒有其他行時引發(fā)StopIteration異常 file.seek(0,0) 重新指向文件的頭部;seek(xx,1)中0代表從文件開頭算起1,1代表從當(dāng)前的位置算起,2代表從文件的末尾算起 file.tell() 返回光標(biāo)在當(dāng)前文件夾中的位置 -
文件的內(nèi)置屬性
文件對象的內(nèi)置屬性 描述 file.closed 表示文件已經(jīng)被關(guān)閉,否則為False file.mode 文件打開時使用的訪問方式 file.name 文件名
# 第一種讀寫文件的方式,不常使用了
# 文件打開之后必須要有關(guān)閉文件的操作
In [1]: f = open('./test.txt','r+')
In [2]: f.read()
Out[2]: '#coding=utf-8\n\nthis is a file\naaaaaaa\nbbbbbbb\nccccccc\niiabcdedfabcdefgi\n'
In [22]: f.read(10)
Out[22]: '#coding=ut'
In [3]: f.write('python')
In [5]: f.seek(0,0) # 重新指向文件的頭部
In [6]: f.read()
Out[6]: '#coding=utf-8\n\nthis is a file\naaaaaaa\nbbbbbbb\nccccccc\niiabcdedfabcdefgi\npython'
In [7]: f.seek(0,0)
In [8]: f.readline() # 從文件中讀寫并返回一行 一般模式下是一行一行的讀取,換行符單獨(dú)算一行
Out[8]: '#coding=utf-8\n'
In [9]: f.readlines(2) # 讀取文件所有的行為作為一個列表返回
Out[9]:
['\n',
'this is a file\n',
'aaaaaaa\n',
'bbbbbbb\n',
'ccccccc\n',
'iiabcdedfabcdefgi\n',
'python']
In [10]: f.mode # 文件打開時的訪問方式
Out[10]: 'r+'
In [11]: f.name
Out[11]: './test.txt'
In [12]: f.close()
# 把列表或者字典寫入到文件中
In [1]: list1 = ['apple','python']
In [2]: file1 = open('./ccc.txt','w+')
In [3]: file1.write(str(list1))
In [4]: file1.tell()
Out[4]: 19
In [5]: file1.seek(0)
In [6]: file1.read()
Out[6]: "['apple', 'python']"
# 把一個文件的內(nèi)容寫入到另一個文件中
with open('file1.txt','r') as f1:
with open('file2.txt','w') as f2:
f2.write(f1.read())
# 第二種讀寫文件的方式,經(jīng)常使用
# 文件打開之后不必執(zhí)行關(guān)閉的操作
In [27]: with open('./test.txt', 'r+') as e:
...: line = e.read(20)
...: lines = e.readlines()
...: write = e.write('python')
...:
In [28]: print line
#coding=utf-8
this
In [29]: print lines
['is a file\n', 'aaaaaaa\n', 'bbbbbbb\n', 'ccccccc\n', 'iiabcdedfabcdefgi\n', 'python']