標籤:
總是記不住API。昨晚寫的時候用到了這些,但是沒記住,於是就索性整理一下吧:
python中對檔案、檔案夾(檔案操作函數)的操作需要涉及到os模組和shutil模組。
得到當前工作目錄,即當前Python指令碼工作的目錄路徑: os.getcwd()
返回指定目錄下的所有檔案和目錄名:os.listdir()
函數用來刪除一個檔案:os.remove()
刪除多個目錄:os.removedirs(r“c:\python”)
檢驗給出的路徑是否是一個檔案:os.path.isfile()
檢驗給出的路徑是否是一個目錄:os.path.isdir()
判斷是否是絕對路徑:os.path.isabs()
檢驗給出的路徑是否真地存:os.path.exists()
返回一個路徑的目錄名和檔案名稱:os.path.split() eg os.path.split(‘/home/swaroop/byte/code/poem.txt‘) 結果:(‘/home/swaroop/byte/code‘, ‘poem.txt‘)
分離副檔名:os.path.splitext()
擷取路徑名:os.path.dirname()
擷取檔案名稱:os.path.basename()
運行shell命令: os.system()
讀取和設定環境變數:os.getenv() 與os.putenv()
給出當前平台使用的行終止符:os.linesep Windows使用‘\r\n‘,Linux使用‘\n‘而Mac使用‘\r‘
指示你正在使用的平台:os.name 對於Windows,它是‘nt‘,而對於Linux/Unix使用者,它是‘posix‘
重新命名:os.rename(old, new)
建立多級目錄:os.makedirs(r“c:\python\test”)
建立單個目錄:os.mkdir(“test”)
擷取檔案屬性:os.stat(file)
修改檔案許可權與時間戳記:os.chmod(file)
終止當前進程:os.exit()
擷取檔案大小:os.path.getsize(filename)
檔案操作:
os.mknod("test.txt") 建立空檔案
fp = open("test.txt",w) 直接開啟一個檔案,如果檔案不存在則建立檔案
關於open 模式:
w 以寫方式開啟,
a 以追加模式開啟 (從 EOF 開始, 必要時建立新檔案)
r+ 以讀寫入模式開啟
w+ 以讀寫入模式開啟 (參見 w )
a+ 以讀寫入模式開啟 (參見 a )
rb 以二進位讀模式開啟
wb 以二進位寫入模式開啟 (參見 w )
ab 以二進位追加模式開啟 (參見 a )
rb+ 以二進位讀寫入模式開啟 (參見 r+ )
wb+ 以二進位讀寫入模式開啟 (參見 w+ )
ab+ 以二進位讀寫入模式開啟 (參見 a+ )
fp.read([size]) #size為讀取的長度,以byte為單位
fp.readline([size]) #讀一行,如果定義了size,有可能返回的只是一行的一部分
fp.readlines([size]) #把檔案每一行作為一個list的一個成員,並返回這個list。其實它的內部是通過迴圈調用readline()來實現的。如果提供size參數,size是表示讀取內容的總長,也就是說可能唯讀到檔案的一部分。
fp.write(str) #把str寫到檔案中,write()並不會在str後加上一個分行符號
fp.writelines(seq) #把seq的內容全部寫到檔案中(多行一次性寫入)。這個函數也只是忠實地寫入,不會在每行後面加上任何東西。
fp.close() #關閉檔案。python會在一個檔案不用後自動關閉檔案,不過這一功能沒有保證,最好還是養成自己關閉的習慣。 如果一個檔案在關閉後還對其進行操作會產生ValueError
fp.flush() #把緩衝區的內容寫入硬碟
fp.fileno() #返回一個長整型的”檔案標籤“
fp.isatty() #檔案是否是一個終端裝置檔案(unix系統中的)
fp.tell() #返迴文件操作標記的當前位置,以檔案的開頭為原點
fp.next() #返回下一行,並將檔案操作標記位移到下一行。把一個file用於for … in file這樣的語句時,就是調用next()函數來實現遍曆的。
fp.seek(offset[,whence]) #將檔案打操作標記移到offset的位置。這個offset一般是相對於檔案的開頭來計算的,一般為正數。但如果提供了whence參數就不一定了,whence可以為0表示從頭開始計算,1表示以當前位置為原點計算。2表示以檔案末尾為原點進行計算。需要注意,如果檔案以a或a+的模式開啟,每次進行寫操作時,檔案操作標記會自動返回到檔案末尾。
fp.truncate([size]) #把檔案裁成規定的大小,預設的是裁到當前檔案操作標記的位置。如果size比檔案的大小還要大,依據系統的不同可能是不改變檔案,也可能是用0把檔案補到相應的大小,也可能是以一些隨機的內容加上去。
目錄操作:
os.mkdir("file") 建立目錄
複製檔案:
shutil.copyfile("oldfile","newfile") oldfile和newfile都只能是檔案
shutil.copy("oldfile","newfile") oldfile只能是檔案夾,newfile可以是檔案,也可以是目標目錄
複製檔案夾:
shutil.copytree("olddir","newdir") olddir和newdir都只能是目錄,且newdir必須不存在
重新命名檔案(目錄)
os.rename("oldname","newname") 檔案或目錄都是使用這條命令
移動檔案(目錄)
shutil.move("oldpos","newpos")
刪除檔案
os.remove("file")
刪除目錄
os.rmdir("dir")只能刪除空目錄
shutil.rmtree("dir") 空目錄、有內容的目錄都可以刪
轉換目錄
os.chdir("path") 換路徑
相關例子
1 將檔案夾下所有圖片名稱加上‘_fc‘
python代碼:
# -*- coding:utf-8 -*-
import re
import os
import time
#str.split(string)分割字串
#‘串連符‘.join(list) 將列表組成字串
def change_name(path):
global i
if not os.path.isdir(path) and not os.path.isfile(path):
return False
if os.path.isfile(path):
file_path =os.path.split(path) #分割出目錄與檔案
lists =file_path[1].split(‘.‘) #分割出檔案與副檔名
file_ext = lists[-1] #取出尾碼名(列表切片操作)
img_ext =[‘bmp‘,‘jpeg‘,‘gif‘,‘psd‘,‘png‘,‘jpg‘]
if file_ext in img_ext:
os.rename(path,file_path[0]+‘/‘+lists[0]+‘_fc.‘+file_ext)
i+=1 #注意這裡的i是一個陷阱
#或者
#img_ext =‘bmp|jpeg|gif|psd|png|jpg‘
#if file_ext in img_ext:
# print(‘ok---‘+file_ext)
elif os.path.isdir(path):
for x in os.listdir(path):
change_name(os.path.join(path,x)) #os.path.join()在路徑處理上很有用
img_dir = ‘D:\\xx\\xx\\images‘
img_dir = img_dir.replace(‘\\‘,‘/‘)
start = time.time()
i = 0
change_name(img_dir)
c = time.time() - start
print(‘程式運行耗時:%0.2f‘%(c))
print(‘總共處理了 %s 張圖片‘%(i))
輸出結果:
程式運行耗時:0.11
總共處理了 109 張圖片
Python:檔案的讀取、建立、追加、刪除、清空
一、用Python建立一個新檔案,內容是從0到9的整數, 每個數字佔一行:
#python
>>>f=open(‘f.txt‘,‘w‘) # r唯讀,w可寫,a追加
>>>for i in range(0,10):f.write(str(i)+‘\n‘)
. . .
>>> f.close()
二、檔案內容追加,從0到9的10個隨機整數:
#python
>>>import random
>>>f=open(‘f.txt‘,‘a‘)
>>>for i in range(0,10):f.write(str(random.randint(0,9)))
. . .
>>>f.write(‘\n‘)
>>>f.close()
三、檔案內容追加,從0到9的隨機整數, 10個數字一行,共10行:
#python
>>> import random
>>> f=open(‘f.txt‘,‘a‘)
>>> for i in range(0,10):
. . . for i inrange(0,10):f.write(str(random.randint(0,9)))
. . . f.write(‘\n‘)
. . .
>>> f.close()
四、把標準輸出定向到檔案:
#python
>>> import sys
>>> sys.stdout = open("stdout.txt", "w")
>>> . . .
五、檔案的讀寫
一、檔案開啟:
f = file(name[, mode[,buffering]])
入口參數: name 檔案名稱
mode 選項,字串
buffering 是否緩衝 (0=不緩衝,1=緩衝, >1的int數=緩衝區大小)
傳回值 : 檔案對象
mode 選項:
"r" 以讀方式開啟,只能讀檔案 , 如果檔案不存在,會發生異常
"w" 以寫方式開啟,只能寫檔案, 如果檔案不存在,建立該檔案
如果檔案已存在,先清空,再開啟檔案
"rb" 以二進位讀方式開啟,只能讀檔案 , 如果檔案不存在,會發生異常
"wb" 以二進位寫方式開啟,只能寫檔案, 如果檔案不存在,建立該檔案
如果檔案已存在,先清空,再開啟檔案
"rt" 以文本讀方式開啟,只能讀檔案 , 如果檔案不存在,會發生異常
"wt" 以文本寫方式開啟,只能寫檔案, 如果檔案不存在,建立該檔案
如果檔案已存在,先清空,再開啟檔案
"rb+" 以二進位讀方式開啟,可以讀、寫檔案 , 如果檔案不存在,會發生異常
"wb+" 以二進位寫方式開啟,可以讀、寫檔案, 如果檔案不存在,建立該檔案
如果檔案已存在,先清空,再開啟檔案
二、關閉檔案
f.close()
當檔案讀寫完畢後,應關閉檔案。
三、清空檔案內容
f.truncate()
注意:僅當以"r+" "rb+" "w" "wb" "wb+"等以可寫入模式開啟的檔案才可以執行該功能。
四、檔案的指標定位與查詢
(1)檔案指標:
檔案被開啟後,其對象儲存在 f 中, 它會記住檔案的當前位置,以便於執行讀、寫操作,這個位置稱為檔案的指標( 一個從檔案頭部開始計算的位元組數 long 類型 )。
(2)檔案開啟時的位置:
以"r" "r+" "rb+" 讀方式, "w" "w+" "wb+"寫方式 開啟的檔案,
一開始,檔案指標均指向檔案的頭部。
(3) 擷取檔案指標的值:
L= f.tell()
(4) 移動檔案的指標
f.seek( 位移量, 選項 )
選項 =0 時, 表示將檔案指標指向從檔案頭部到 "位移量"位元組處。
選項 =1 時, 表示將檔案指標指向從檔案的當前位置,向後移動 "位移量"位元組。
選項 =2 時, 表示將檔案指標指向從檔案的尾部,,向前移動 "位移量"位元組。
五、從檔案讀取指內容
1 文字檔(以"rt"方式開啟的檔案)的讀取
s = f.readline( )
傳回值: s 是字串,從檔案中讀取的一行,含行結束符。
說明: (1) 如果 len( s ) =0 表示已到檔案尾
(2) 如果是檔案的最後一行,有可能沒有行結束符
2 二進位檔案(以"rb"、"rb+"、"wb+" 方式開啟的檔案)的讀取
s = f.read( n )
說明: (1) 如果 len( s ) =0 表示已到檔案尾
(2) 檔案讀取後,檔案的指標向後移動 len(s) 位元組。
(3)如果磁軌已壞,會發生異常。
六、向檔案寫入一個字串
f.write( s )
參數: s 要寫入的字串
說明: (1)檔案寫入後,檔案的指標向後移動 len(s) 位元組。
(2)如果磁軌已壞,或磁碟已滿會發生異常。
傳回值: s 是字串,從檔案中讀取的內容
七、刪除檔案
import os
os.remove(file)
python檔案操作