python 遍歷磁盤目錄的三種方法
import osdef get_files(path): # 判斷路徑是否存在,如果不存在,函數(shù)直接結(jié)束 if not os.path.exists(path): print(’路徑不存在’) return # 判斷路徑是否為文件夾 if not os.path.isdir(path): print(’路徑是一個文件’) return # 這時候,路徑是一個文件夾 # 獲取文件夾中文件或文件夾的名稱 file_list = os.listdir(path) # 遍歷文件夾 for filename in file_list: # 拼接路徑,獲取每個次級目錄下的文件路徑 subpath = os.path.join(path,filename) if os.path.isfile(subpath): if os.path.splitext(subpath)[1] == ’.py’:print(’python文件:{}’.format(subpath)) else: # 如果filename是文件夾,則調(diào)用函數(shù)繼續(xù)遍歷 get_files(subpath)用棧來遍歷磁盤
棧的特點:先進(jìn)后廚,后進(jìn)先出原理:path第一次被pop刪除后返回path,遍歷目錄下的文件,如果遇到文件夾追加到列表中,pop是刪除最后一位的元素,每次又遍歷最后一位的文件夾,所以每一輪都會將次級目錄下的文件夾遍歷完成之后再遍歷下個次級目錄
import osdef get_files(path): # 判斷路徑是否存在 if not os.path.exists(path): print(’路徑不存在’) return if not os.path.isdir(path): print(’路徑是一個文件夾’) return # 創(chuàng)建一個列表作為棧 stack = [path] # 取出棧中的元素 while len(stack) != 0: path = stack.pop() file_list = os.listdir(path) for filename in file_list: subpath = os.path.join(path,filename) if os.path.isfile(subpath):print(’python文件:{}’.format(subpath)) else:stack.append(subpath)廣度遍歷磁盤用隊列遍歷磁盤
import osimport collectionsdef get_py_file(path): # 判斷路徑是否存在 if not os.path.exists(path): print(’路徑不存在’) return # 判斷路徑是否是文件夾 if os.path.isfile(path): print(’路徑是文件’) return # path是一個文件夾 # 定義一個空對列 queue = collections.deque() queue.append(path) while len(queue) != 0: # 從隊列中獲取第一個元素 path = queue.popleft() # 獲取目錄下的所有內(nèi)容 filelist = os.listdir(path) # 遍歷 for filename in filelist: # 拼接 filepath = os.path.join(path, filename) if os.path.isfile(filepath):if os.path.splitext(filepath)[1] == ’.py’: print(filepath) else:queue.append(filepath)
以上就是python 遍歷磁盤目錄的三種方法的詳細(xì)內(nèi)容,更多關(guān)于python 遍歷磁盤目錄的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Android實現(xiàn)動態(tài)改變shape.xml中圖形的顏色2. Vue實現(xiàn)div滾輪放大縮小3. PHP擴(kuò)展之APC——Alternative PHP Cache(可選PHP緩存)4. Android中的緩存5. APP啟動慢怎么辦,Android官方這樣說6. VUE實時監(jiān)聽元素距離頂部高度的操作7. Android基于OpenCV實現(xiàn)圖像修復(fù)8. 解決Android Studio日志太長或滾動太快問題9. 如何從外部瀏覽開啟Android App10. android RecycleView實現(xiàn)多級樹形列表
