python之檔案的讀寫和檔案目錄以及檔案夾的操作

來源:互聯網
上載者:User

標籤:

為了安全起見,最好還是給開啟的檔案對象指定一個名字,這樣在完成操作之後可以迅速關閉檔案,防止一些無用的檔案對象佔用記憶體。舉個例子,對文字檔讀取:
file_object = open(‘thefile.txt‘)
try:
all_the_text = file_object.read( )
finally:

file_object.close( )


Python讀寫檔案實際操作的五大步驟

一、開啟檔案

Python讀寫檔案在電腦語言中被廣泛的應用,如果你想瞭解其應用的程式,以下的文章會給你詳細的介紹相關內容,會你在以後的學習的過程中有所協助,下面我們就詳細介紹其應用程式。
代碼如下:

 
  1. f = open("d:\test.txt", "w")  

說明:

第一個參數是檔案名稱,包括路徑;第二個參數是開啟的模式mode
‘r‘:唯讀(預設。如果檔案不存在,則拋出錯誤)
‘w‘:唯寫(如果檔案不存在,則自動建立檔案)
‘a‘:附加到檔案末尾
‘r+‘:讀寫
如果需要以二進位方式開啟檔案,需要在mode後面加上字元"b",比如"rb""wb"等
二、讀取內容

 
  1. f.read(size)  

參數size表示讀取的數量,可以省略。如果省略size參數,則表示讀取檔案所有內容。

 
  1. f.readline()  

讀取檔案一行的內容

 
  1. f.readlines()  

讀取所有的行到數組裡面[line1,line2,...lineN]。在避免將所有檔案內容載入到記憶體中,這種方法常常使用,便於提高效率。

三、寫入檔案

 
  1. f.write(string)  

將一個字串寫入檔案,如果寫入結束,必須在字串後面加上"\n",然後f.close()關閉檔案
四、檔案中的內容定位

 
  1. f.read() 

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

 
  1. f.seek(0)  

這個函數的格式如下(單位是bytes):

 
  1. f.seek(offset, from_what)  

from_what表示開始讀取的位置,offset表示從from_what再移動一定量的距離,比如f.seek(10, 3)表示定位到第三個字元並再後移10個字元。from_what值為0時表示檔案的開始,它也可以省略,預設是0即檔案開頭。下面給出一

 
  1. f = open(‘/tmp/workfile‘, ‘r+‘)  
  2. f.write(‘0123456789abcdef‘)  
  3. f.seek(5) # Go to the 6th byte in the file  
  4. f.read(1)   
  5. ‘5‘  
  6. f.seek (-3, 2) # Go to the 3rd byte before the end  
  7. f.read(1)  
  8. ‘d‘  
  9.  

五、關閉檔案釋放資源

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

Python讀寫檔案在電腦語言中被廣泛的應用,如果你想瞭解其應用的程式,以下的文章會給你詳細的介紹相關內容,會你在以後的學習的過程中有所協助,下面我們就詳細介紹其應用程式。





一、python中對檔案、檔案夾操作時經常用到的os模組和shutil模組常用方法。
1.得到當前工作目錄,即當前Python指令碼工作的目錄路徑: os.getcwd()
2.返回指定目錄下的所有檔案和目錄名:os.listdir()
3.函數用來刪除一個檔案:os.remove()
4.刪除多個目錄:os.removedirs(r"c:\python")
5.檢驗給出的路徑是否是一個檔案:os.path.isfile()
6.檢驗給出的路徑是否是一個目錄:os.path.isdir()
7.判斷是否是絕對路徑:os.path.isabs()
8.檢驗給出的路徑是否真地存:os.path.exists()
9.返回一個路徑的目錄名和檔案名稱:os.path.split()    
例子:

代碼如下:os.path.split(‘/home/swaroop/byte/code/poem.txt‘) 結果:(‘/home/swaroop/byte/code‘, ‘poem.txt‘)
10.分離副檔名:os.path.splitext()
11.擷取路徑名:os.path.dirname()
12.擷取檔案名稱:os.path.basename()
13.運行shell命令: os.system()
14.讀取和設定環境變數:os.getenv() 與os.putenv()
15.給出當前平台使用的行終止符:os.linesep    Windows使用‘\r\n‘,Linux使用‘\n‘而Mac使用‘\r‘
16.指示你正在使用的平台:os.name       對於Windows,它是‘nt‘,而對於Linux/Unix使用者,它是‘posix‘
17.重新命名:os.rename(old, new)
18.建立多級目錄:os.makedirs(r"c:\python\test")
19.建立單個目錄:os.mkdir("test")
20.擷取檔案屬性:os.stat(file)
21.修改檔案許可權與時間戳記:os.chmod(file)
22.終止當前進程:os.exit()
23.擷取檔案大小:os.path.getsize(filename)
二、檔案操作方法大全
1.os.mknod("test.txt")        建立空檔案
2.fp = open("test.txt",w)     直接開啟一個檔案,如果檔案不存在則建立檔案
3.關於open 模式:
複製代碼 代碼如下:r:以讀方式開啟檔案,可讀取檔案資訊。
w:以寫方式開啟檔案,可向檔案寫入資訊。如檔案存在,則清空該檔案,再寫入新內容
a:以追加模式開啟檔案(即一開啟檔案,檔案指標自動移到檔案末尾),如果檔案不存在則建立
b:以二進位模式開啟檔案,而不是以文字模式。該模式只對Windows或Dos有效,類Unix的檔案是用二進位模式進行操作的。
r+:以讀寫入模式開啟
w+:以讀寫入模式開啟 (參見 w )
a+:以讀寫入模式開啟 (參見 a )
rb:以二進位讀模式開啟
wb:以二進位寫入模式開啟 (參見 w )
ab:以二進位追加模式開啟 (參見 a )
rb+:以二進位讀寫入模式開啟 (參見 r+ )
wb+:以二進位讀寫入模式開啟 (參見 w+ )
ab+:以二進位讀寫入模式開啟 (參見 a+ )



檔案對象方法
f.close():關閉檔案,記住用open()開啟檔案後一定要記得關閉它,否則會佔用系統的可開啟檔案控制代碼數。
f.fileno():獲得檔案描述符,是一個數字
f.flush():重新整理輸出緩衝
f.isatty():如果檔案是一個互動終端,則返回True,否則返回False。
f.read([count]):讀出檔案,如果有count,則讀出count個位元組。
f.readline():讀出一行資訊。
f.readlines():
讀出所有行,也就是讀出整個檔案的資訊。
f.seek(offset[,where]):把檔案指標移動到相對於where的offset位置。where為0表示檔案開始處,這是預設值 ;1表示當前位置;2表示檔案結尾。
f.tell():獲得檔案指標位置。
f.truncate([size]):截取檔案,使檔案的大小為size。
f.write(string):把string字串寫入檔案。
f.writelines(list):把list中的字串一行一行地寫入檔案,是連續寫入檔案,沒有換行。


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把檔案補到相應的大小,也可能是以一些隨機的內容加上去。
三、目錄操作方法大全
1.建立目錄
os.mkdir("file")                  
2.複製檔案:
shutil.copyfile("oldfile","newfile")        #oldfile和newfile都只能是檔案
shutil.copy("oldfile","newfile")            #oldfile只能是檔案夾,newfile可以是檔案,也可以是目標目錄
3.複製檔案夾:
4.shutil.copytree("olddir","newdir")        #olddir和newdir都只能是目錄,且newdir必須不存在
5.重新命名檔案(目錄)
os.rename("oldname","newname")              #檔案或目錄都是使用這條命令
6.移動檔案(目錄)
shutil.move("oldpos","newpos")  
7.刪除檔案
os.remove("file")
8.刪除目錄
os.rmdir("dir")                             #只能刪除空目錄
shutil.rmtree("dir")                        #空目錄、有內容的目錄都可以刪
9.轉換目錄
os.chdir("path")                            #換路徑



目錄操作:
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")   換路徑


編程執行個體:

# -*- coding: utf-8 -*-import osimport shutil# 一. 路徑操作:判斷、擷取和刪除#1. 得到當前工作目錄,即當前Python指令碼工作的目錄路徑: os.getcwd()#print: currentpath:  f:\LearnPythoncurrentpath = os.getcwd()print "currentpath: ",currentpath#2. 返回指定目錄下的所有檔案和目錄名:os.listdir()#print:os.listdir():  ['test.txt', 'testRW.py', 'test1.txt', 'cmd.py', 'rwfile.py', 'downloadfile.py', 'date.py', 'time.py', 'datetime.py', 'file.py']print "os.listdir(): ",os.listdir('f:\LearnPython')path = "F:\mmmmmmmmm\[email protected]_android1.6_3.2.1.apk"#3. 判斷給出的路徑是否真地存:os.path.exists()if os.path.exists(path):#刪除一個檔案:os.remove()os.remove(path)else:print path,"not exist"#4. 刪除多個目錄:os.removedirs(“c:\python”)#它只能刪除空目錄,如果目錄裡面有內容將不會被刪除if os.path.exists("d:/woqu"):os.removedirs("d:/woqu")else:os.mkdir("d:/woqu")os.removedirs("d:/woqu")#5. 判斷給出的路徑是否是一個檔案:os.path.isfile()#print: Trueprint os.path.isfile("D:\hello\json.txt")#6. 判斷給出的路徑是否是一個目錄:os.path.isdir()#print: Trueprint os.path.isdir("D:\hello")#7. 判斷是否是絕對路徑:os.path.isabs()#print: Trueprint os.path.isabs("D:\hello")#  判斷是否是連結print os.path.islink('http://www.baidu.com')#8. 返回一個路徑的目錄名和檔案名稱:os.path.split()     #eg os.path.split('/home/swaroop/byte/code/poem.txt') 結果:('/home/swaroop/byte/code', 'poem.txt') #print: ('D:\\hello', 'json.txt')print os.path.split("D:\hello\json.txt")#9. 分離副檔名:os.path.splitext()#print:('D:\\hello\\json', '.txt')print os.path.splitext("D:\hello\json.txt")#10. 擷取路徑名:os.path.dirname()#print: 'D:\\hello'print os.path.dirname("D:\hello\json.txt")#11. 擷取檔案名稱:os.path.basename()#print: 'json.txt'print os.path.basename("D:\hello\json.txt")#13. 指示你正在使用的平台:os.name       對於Windows,它是'nt',而對於Linux/Unix使用者,它是'posix'print "os.name: ",os.name#14. linex 下的命令if os.name == 'posix':#讀取和設定環境變數:os.getenv() 與os.putenv()    home_path = os.environ['HOME']    home_path = os.getenv('HOME')  #讀取環境變數 elif os.name == 'nt':    home_path = 'd:'     print 'home_path: ',home_path#15. 給出當前平台使用的行終止符:os.linesep    Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'print(os.linesep)#16. 應為windows和linux的路徑有點點不一樣,windows是用 \\ 來分割的,linux是用 / 來分隔,#而用os.sep 會自動根據系統選擇用哪個分隔字元。print(os.sep)#17. 重新命名:os.rename(old, new)#先進入目錄os.chdir("d:\\hello")print os.getcwd() #18. 再重新命名os.rename("1.txt", "11.txt")#19. 建立多級目錄:os.makedirs(“c:\python\test”)os.makedirs('d:\h\e\l\l\o')#20. 建立單個目錄:os.mkdir(“test”)os.mkdir('d:\f')#21. 擷取檔案屬性:os.stat(file)#print: nt.stat_result(st_mode=33206, st_ino=0L, st_dev=0, st_nlink=0, st_uid=0, st_gid=0, st_size=497L, st_atime=1346688000L, st_mtime=1346748054L, st_ctime=1346748052L)print os.stat('d:\hello\json.txt')#22. 修改檔案許可權與時間戳記:os.chmod(path,mode)#這裡有介紹:http://blog.csdn.net/wirelessqa/article/details/7974477#23. 終止當前進程:os.exit()#24. 擷取檔案大小:os.path.getsize(filename)print os.path.getsize('d:/hello/json.txt')


python中如何將列表寫入檔案:

執行個體:

a = [1,2,3,4,5,6,7,8,9]tmp = []for i in range(0,len(a),3): tmp.append(str(a[i])+","+str(a[i+1])+","+str(a[i+2])+"\n")file("./a.txt",'w').writelines(tmp)

python 讀取txt檔案到列表中

執行個體:

假如txt檔案內容為:aaa,bbb,ccc                 ddd,eee,fff我要讀取儲存到列表中去,顯示結果為[[aaa,bbb,ccc],[ddd,eee,fff]]

txtpath=r"a.txt"fp=open(txtpath)arr=[]for lines in fp.readlines():    lines=lines.replace("\n","").split(",")    arr.append(lines)fp.close()


參考文獻:

http://blog.csdn.net/wirelessqa/article/details/7974531

http://www.cnblogs.com/rollenholt/archive/2012/04/23/2466179.html

http://zhidao.baidu.co/link?url=CipzeDdunK4rP7S0eGIcbamIu9SeYaW_ccCF093WaWdStXAjXd1UrbjmZ7A2s9pQVNOMKAgwBkJQkeEmlngLAnkPFJyfT9rKFpYUqrFO0kS

http://zhidao.baidu.com/link?url=MnXJPJhtztPs6kgJkMlea_tkHLRYenQcu7O6IUetgpNQFIoM-9gh4-GuOKvprVOeiguPxM_66mZpatvTzS-iwa



python之檔案的讀寫和檔案目錄以及檔案夾的操作

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.