萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> python文件操作之目錄遍歷實例分析

python文件操作之目錄遍歷實例分析

   本文實例講述了python文件操作之目錄遍歷的方法。分享給大家供大家參考。具體分析如下:

  Python的os模塊,包含了普遍的操作系統功能,這裡主要學習與路徑相關的函數:

  os.listdir(dirname):列出dirname下的目錄和文件

  os.getcwd():獲得當前工作目錄

  os.curdir:返回當前目錄('.')

  os.chdir(dirname):改變工作目錄到dirname

  os.path.isdir(name):判斷name是不是一個目錄,name不是目錄就返回false

  os.path.isfile(name):判斷name是不是一個文件,不存在name也返回false

  os.path.exists(name):判斷是否存在文件或目錄name

  os.path.getsize(name):獲得文件大小,如果name是目錄返回0

  os.path.abspath(name):獲得絕對路徑

  os.path.normpath(path):規范path字符串形式

  os.path.split(name):分割文件名與目錄(事實上,如果你完全使用目錄,它也會將最後一個目錄作為文件名而分離,同時它不會判斷文件或目錄是否存在)

  os.path.splitext():分離文件名與擴展名

  os.path.join(path,name):連接目錄與文件名或目錄

  os.path.basename(path):返回文件名

  os.path.dirname(path):返回文件路徑

  1、os.path方法

  通過傳入需要遍歷的目錄,列出目錄下的所有文件並統計文件數,os提供的path模塊能對目錄非常靈活的操作。

  ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 import os,sys def listdir(dir,file): file.write(dir + 'n') fielnum = 0 list = os.listdir(dir) #列出目錄下的所有文件和目錄 for line in list: filepath = os.path.join(dir,line) if os.path.isdir(filepath): #如果filepath是目錄,則再列出該目錄下的所有文件 myfile.write(' ' + line + ''+'n') for li in os.listdir(filepath): myfile.write(' '+li + 'n') fielnum = fielnum + 1 elif os.path: #如果filepath是文件,直接列出文件名 myfile.write(' '+line + 'n') fielnum = fielnum + 1 myfile.write('all the file num is '+ str(fielnum)) dir = raw_input('please input the path:') myfile = open('list.txt','w')

  2、os.walk方法

  os模塊提供的walk方法很強大,能夠把給定的目錄下的所有目錄和文件遍歷出來。

  方法:os.walk(path),遍歷path,返回一個對象,他的每個部分都是一個三元組,('目錄x',[目錄x下的目錄list],目錄x下面的文件)

  ?

1 2 3 4 5 6 7 8 9 10 11 12 import os def walk_dir(dir,fileinfo,topdown=True): for root, dirs, files in os.walk(dir, topdown): for name in files: print(os.path.join(name)) fileinfo.write(os.path.join(root,name) + 'n') for name in dirs: print(os.path.join(name)) fileinfo.write(' ' + os.path.join(root,name) + 'n') dir = raw_input('please input the path:') fileinfo = open('list.txt','w') walk_dir(dir,fileinfo)

  topdown決定遍歷的順序,如果topdown為True,則先列舉top下的目錄,然後是目錄的目錄,依次類推,反之,則先遞歸列舉出最深層的子目錄,然後是其兄弟目錄,然後子目錄。

  希望本文所述對大家的Python程序設計有所幫助。

copyright © 萬盛學電腦網 all rights reserved