python命令行運行py文件「python運行文件指令」

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 對象常用的函數:

序號方法及描述
1file.close()關閉文件。關閉後文件不能再進行讀寫操作。
2file.flush()刷新文件內部緩衝,直接把內部緩衝區的數據立刻寫入文件, 而不是被動的等待輸出緩衝區寫入。
3file.fileno()返回一個整型的文件描述符(file descriptor FD 整型), 可以用在如os模塊的read方法等一些底層操作上。
4file.isatty()如果文件連接到一個終端設備返回 True,否則返回 False。
5file.next()返迴文件下一行。
6file.read([size])從文件讀取指定的位元組數,如果未給定或為負則讀取所有。
7file.readline([size])讀取整行,包括 “\n” 字元。
8file.readlines([sizeint])讀取所有行並返回列表,若給定sizeint>0,則是設置一次讀多少位元組,這是為了減輕讀取壓力。
9file.seek(offset[, whence])設置文件當前位置
10file.tell()返迴文件當前位置。
11file.truncate([size])截取文件,截取的位元組通過size指定,默認為當前文件位置。
12file.write(str)將字元串寫入文件,返回的是寫入的字元長度。
13file.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’]

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/252582.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-14 02:17
下一篇 2024-12-14 02:17

相關推薦

發表回復

登錄後才能評論