Python檔案操作 開啟,讀取,關閉

2021-05-22 20:45:10 字數 3494 閱讀 9437

1.開啟檔案**如下:

>>> f = open(」d:test.txt」, 「w」)

說明:第乙個引數是檔名稱,包括路徑;第二個引數是開啟的模式mode』r':唯讀(預設。如果檔案不存在,則丟擲錯誤)』w':只寫(如果檔案 不存在,則自動建立檔案)』a':附加到檔案末尾』r+』:讀寫如果需要以二進位制方式開啟檔案,需要在mode後面加上字元」b」,比如」rb」"wb」 等

2.讀取內容f.read(size)引數size表示讀取的數量,可以省略。如果省略size引數,則表示讀取檔案所有內容。 f.readline()讀取檔案一行的內容f.readlines()讀取所有的行到陣列裡面[line1,line2,...linen]。在避免將 所有檔案內容載入到記憶體中,這種方法常常使用,便於提高效率。

3.寫入檔案f.write(string) 將乙個字串寫入檔案,如果寫入結束,必須在字串後面加上」n」,然後f.close()關閉檔案

4.檔案中的內容定位f.read()讀取之後,檔案指標到達檔案的末尾,如果再來一次f.read()將會發現讀取的是空內容,如果想再次讀取全 部內容,必須將定位指標移動到檔案開始:

f.seek(0)這個函式的格式如下(單位是bytes):f.seek(offset, from_what)from_what表示開始讀取的位置,offset表示從from_what再移動一定量的距離,比如f.seek(10, 3)表示定位到第三個字元並再後移10個字元。from_what值為0時表示檔案的開始,它也可以省略,預設是0即檔案開頭。下面給出乙個完整的例 子:>>> f = open(』/tmp/workfile』, 『r+』)

>>> f.write(』0123456789abcdef』)

>>> f.seek(5) # go to the 6th byte in the file

>>> f.read(1)

『5′>>> f.seek (-3, 2) # go to the 3rd byte before the end

>>> f.read(1)

『d』

5.關閉檔案釋放資源檔案操作完畢,一定要記得關閉檔案f.close(),可以釋放資源供其他程式使用

* file(name[, mode[, buffering]])

file()函式用於建立乙個file物件,它有乙個別名叫open(),可能更形象一些,它們是內建函式。來看看它的引數。它引數都是以字串的 形式傳遞的。

name是檔案的名字。

mode 是開啟的模式,可選的值為r w a u,分別代表讀(預設) 寫 新增支援各種換行符的模式。用w或a模式開啟檔案的話,如果檔案不存在,那麼就自動建立。此外,用w模式開啟乙個已經存在的檔案時,原有檔案的內容會被清 空,因為一開始檔案的操作的標記是在檔案的開頭的,這時候進行寫操作,無疑會把原有的內容給抹掉。由於歷史的原因,換行符在不同的系統中有不同模式,比如 在 unix中是乙個n,而在windows中是』rn』,用u模式開啟檔案,就是支援所有的換行模式,也就說』r』 『n』 『rn』都可表示換行,會有乙個tuple用來存貯這個檔案中用到過的換行符。不過,雖說換行有多種模式,讀到python中統一用n代替。在模式 字元的後面,還可以加上+ b t這兩種標識,分別表示可以對檔案同時進行讀寫操作和用二進位制模式、文字模式(預設)開啟檔案。

buffering如果為0表示不進行緩衝;如果為1表示進行」行緩衝」;如果是乙個大於1的數表示緩衝區的大小,應該是以位元組為單位的。

file物件有自己的屬性和方法。先來看看file的屬性。

--------------------------------------

closed #標記檔案是否已經關閉,由close()改寫

encoding #檔案編碼

mode #開啟模式

name #檔名

newlines #檔案中用到的換行模式,是乙個tuple

softspace #boolean型,一般為0,據說用於print

file的讀寫方法:

* f.read([size]) #size為讀取的長度,以byte為單位

* f.readline([size])

#讀一行,如果定義了size,有可能返回的只是一行的一部分

* f.readlines([size])

#把檔案每一行作為乙個list的乙個成員,並返回這個list。其實它的內部是通過迴圈呼叫readline()來實現的。如果提供size參 數,size是表示讀取內容的總長,也就是說可能唯讀到檔案的一部分。

* f.write(str)

#把str寫到檔案中,write()並不會在str後加上乙個換行符

* f.writelines(seq)

#把seq的內容全部寫到檔案中。這個函式也只是忠實地寫入,不會在每行後面加上任何東西。

file的其他方法:

* f.close()

#關閉檔案。python會在乙個檔案不用後自動關閉檔案,不過這一功能沒***,最好還是養成自己關閉的習慣。如果乙個檔案在關閉後還對其進行操作會產 生valueerror

* f.flush()

#把緩衝區的內容寫入硬碟

* f.fileno()

#返回乙個長整型的」檔案標籤」

* f.isatty()

#檔案是否是乙個終端裝置檔案(unix系統中的)

* f.tell()

#返回檔案操作標記的當前位置,以檔案的開頭為原點

* f.next()

#返回下一行,並將檔案操作標記位移到下一行。把乙個file用於for … in file這樣的語句時,就是呼叫next()函式來實現遍歷的。

* f.seek(offset[,whence])

# 將檔案打操作標記移到offset的位置。這個offset一般是相對於檔案的開頭來計算的,一般為正數。但如果提供了whence引數就不一定了, whence可以為0表示從頭開始計算,1表示以當前位置為原點計算。2表示以檔案末尾為原點進行計算。需要注意,如果檔案以a或a+的模式開啟,每次進 行寫操作時,檔案操作標記會自動返回到檔案末尾。

* f.truncate([size])

#把檔案裁成規定的大小,預設的是裁到當前檔案操作標記的位置。如果size比檔案的大小還要大,依據系統的不同可能是不改變檔案,也可能是用0把檔案補 到相應的大小,也可能是以一些隨機的內容加上去。

例子:有兩個磁碟檔案a和b,各存放一行字母,要求把這兩個檔案中的資訊合併(按字母順序排列),

輸出到乙個新檔案c中.

'''if __name__ == '__main__':

import string

fp1 = open('e://a.txt')

a = fp1.read()

fp1.close()

fp2 = open('e://b.txt')

b = fp2.read()

fp2.close()

fp3 = open('e://c.txt','w')

l = list(a + b)

l.sort()

s = ''

s = s.join(l)

fp3.write(s)

fp3.close()

Python檔案操作 開啟,讀取,關閉

1.開啟檔案 如下 f open d test.txt w 說明 第乙個引數是檔名稱,包括路徑 第二個引數是開啟的模式mode r 唯讀 預設。如果檔案不存在,則丟擲錯誤 w 只寫 如果檔案 不存在,則自動建立檔案 a 附加到檔案末尾 r 讀寫如果需要以二進位制方式開啟檔案,需要在mode後面加上字...

python檔案讀取操作

r 讀模式 w 寫模式 a 追加模式 b 二進位制模式 可新增到其他模式中使用 讀或者寫模式 可新增到其他模式中使用 read 方法 一次讀取檔案所有內容。a.txt檔案內容如下 hello,world 例項 f open a.txt r a f.read f.close print a 輸出 he...

python 檔案的開啟與讀取

其實網上其他人寫的都挺好的,我也是看他們的。辦公室用的2.7。筆記本用的3.6.發現沒有file 類,尷尬了 with open r c users hbx documents 新建資料夾 baixi.txt r as f print f.read f.close if f.close 1 prin...