Python File(文件) 方法
open() 方法
Python open() 方法用于打開一個文件,并返回文件對象,在對文件進行處理過程都需要使用到這個函數,如果該文件無法被打開,會拋出 OSError。
注意:使用 open() 方法一定要保證關閉文件對象,即調用 close() 方法。
open() 函數常用形式是接收兩個參數:文件名(file)和模式(mode)。
open(file, mode='r')
mode 參數有:
模式 | 描述 |
t | 文本模式 (默認)。 |
x | 寫模式,新建一個文件,如果該文件已存在則會報錯。 |
b | 二進制模式。 |
+ | 打開一個文件進行更新(可讀可寫)。 |
U | 通用換行模式(不推薦)。 |
r | 以只讀方式打開文件。文件的指針將會放在文件的開頭。這是默認模式。 |
rb | 以二進制格式打開一個文件用于只讀。文件指針將會放在文件的開頭。這是默認模式。一般用于非文本文件如圖片等。 |
r+ | 打開一個文件用于讀寫。文件指針將會放在文件的開頭。 |
rb+ | 以二進制格式打開一個文件用于讀寫。文件指針將會放在文件的開頭。一般用于非文本文件如圖片等。 |
w | 打開一個文件只用于寫入。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內容會被刪除。如果該文件不存在,創建新文件。 |
wb | 以二進制格式打開一個文件只用于寫入。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內容會被刪除。如果該文件不存在,創建新文件。一般用于非文本文件如圖片等。 |
w+ | 打開一個文件用于讀寫。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內容會被刪除。如果該文件不存在,創建新文件。 |
wb+ | 以二進制格式打開一個文件用于讀寫。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內容會被刪除。如果該文件不存在,創建新文件。一般用于非文本文件如圖片等。 |
a | 打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。也就是說,新的內容將會被寫入到已有內容之后。如果該文件不存在,創建新文件進行寫入。 |
ab | 以二進制格式打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。也就是說,新的內容將會被寫入到已有內容之后。如果該文件不存在,創建新文件進行寫入。 |
a+ | 打開一個文件用于讀寫。如果該文件已存在,文件指針將會放在文件的結尾。文件打開時會是追加模式。如果該文件不存在,創建新文件用于讀寫。 |
ab+ | 以二進制格式打開一個文件用于追加。如果該文件已存在,文件指針將會放在文件的結尾。如果該文件不存在,創建新文件用于讀寫。 |
默認為文本模式,如果要以二進制模式打開,加上 b 。
file 對象
file 對象使用 open 函數來創建,下表列出了 file 對象常用的函數:
序號 | 方法及描述 |
1 | file.close()關閉文件。關閉后文件不能再進行讀寫操作。 |
2 | file.flush()刷新文件內部緩沖,直接把內部緩沖區的數據立刻寫入文件, 而不是被動的等待輸出緩沖區寫入。 |
3 | file.fileno()返回一個整型的文件描述符(file descriptor FD 整型), 可以用在如os模塊的read方法等一些底層操作上。 |
4 | file.isatty()如果文件連接到一個終端設備返回 True,否則返回 False。 |
5 | file.next()返回文件下一行。 |
6 | file.read([size])從文件讀取指定的字節數,如果未給定或為負則讀取所有。 |
7 | file.readline([size])讀取整行,包括 “\n” 字符。 |
8 | file.readlines([sizeint])讀取所有行并返回列表,若給定sizeint>0,則是設置一次讀多少字節,這是為了減輕讀取壓力。 |
9 | file.seek(offset[, whence])設置文件當前位置 |
10 | file.tell()返回文件當前位置。 |
11 | file.truncate([size])截取文件,截取的字節通過size指定,默認為當前文件位置。 |
12 | file.write(str)將字符串寫入文件,返回的是寫入的字符長度。 |
13 | file.writelines(sequence)向文件寫入一個序列字符串列表,如果需要換行則要自己加入每行的換行符。 |
【文件讀寫操作示例】
1》將文件companies.txt中的字符串前加上序號1,2,3……后,寫到另一個文件scompanies.txt中。
>>> f1=open(r’C:\Users\Administrator\Desktop\companies.txt’,’r’)
>>> companyNames=f1.readlines()
>>> for i in range(0,len(companyNames)):
… companyNames[i]=str(i+1)+’ ‘+companyNames[i]
…
>>> f1.close()
>>> f2=open(r’C:\Users\Administrator\Desktop\scompanies.txt’,’w’)
>>> f2.writelines(companyNames)
>>> f2.close()
2》打開文件companies.txt,在尾部追加一行’alibaba’,然后讀出文件內容。
>>> f1=open(r’C:\Users\Administrator\Desktop\companies.txt’,’a+’)
>>> f1.write(‘\n’)
>>> f1.write(‘alibaba’)
>>> f1.seek(0,0)
>>> l=f1.readlines()
>>> f1.close()
>>> l
[‘Apple Inc.\n’, ‘Google Inc.\n’, ‘Facebook,Inc.\n’, ‘Microsoft Corporation\n’, ‘alibaba’]
3》打開文件companies.txt,在第二行后,添加一獨立的新行’love python’。
>>> f=open(r”C:\Users\Administrator\Desktop\companies.txt”,’r+’)#注意打開模式
>>> n=2
>>> l=f.readlines()
>>> l
[‘Apple Inc.\n’, ‘Google Inc.\n’, ‘Facebook,Inc.\n’, ‘Microsoft Corporation\n’, ‘alibaba’]
>>> l.insert(n,’love python\n’)#字符串末尾記得寫換行符
>>> l
[‘Apple Inc.\n’, ‘Google Inc.\n’, ‘love python\n’, ‘Facebook,Inc.\n’, ‘Microsoft Corporation\n’, ‘alibaba’]
>>> f.seek(0)#將文件指針移到文件開頭
>>> f.writelines(l)
>>> f.close()
4》讀取整個文件的內容
可以直接使用readlines()函數,如下:
>>> f=open(r”C:\Users\Administrator\Desktop\companies.txt”,’r’)
>>> l=f.readlines()
>>> f.close()
>>> print l
[‘Apple Inc.\n’, ‘Google Inc.\n’, ‘love python\n’, ‘Facebook,Inc.\n’, ‘Microsoft Corporation\n’, ‘alibaba’]
5》讀取整個文件內容,不使用readlines()函數,如下:
>>> f=open(r”C:\Users\Administrator\Desktop\companies.txt”,’r’)
>>> lines=[]
>>> for line in f: #文件是一個可迭代對象
… lines.append(line)
…
>>> f.close()
>>> print lines
[‘Apple Inc.\n’, ‘Google Inc.\n’, ‘love python\n’, ‘Facebook,Inc.\n’, ‘Microsoft Corporation\n’, ‘alibaba’]
版權聲明:本文內容由互聯網用戶自發貢獻,該文觀點僅代表作者本人。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如發現本站有涉嫌抄襲侵權/違法違規的內容, 請發送郵件至 舉報,一經查實,本站將立刻刪除。