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)用棧來遍歷磁盤
棧的特點:先進后廚,后進先出原理: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 遍歷磁盤目錄的三種方法的詳細內(nèi)容,更多關(guān)于python 遍歷磁盤目錄的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Android 7.0 運行時權(quán)限彈窗問題的解決2. java實現(xiàn)圖形化界面計算器3. IntelliJ IDEA設(shè)置條件斷點的方法步驟4. IDEA的Mybatis Generator駝峰配置問題5. ASP.NET MVC解決上傳圖片臟數(shù)據(jù)的方法6. 如何利用python和DOS獲取wifi密碼7. Thinkphp3.2.3反序列化漏洞實例分析8. python Xpath語法的使用9. 原生js XMLhttprequest請求onreadystatechange執(zhí)行兩次的解決10. python 批量將PPT導(dǎo)出成圖片集的案例
