深度遍歷
遞歸
import os
def get_files(path):
# 判斷路徑是否存在,如果不存在,函數直接結束
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是文件夾,則調用函數繼續遍歷
get_files(subpath)
用棧來遍歷磁盤
棧的特點:先進后廚,后進先出
原理:path第一次被pop刪除后返回path,遍歷目錄下的文件,如果遇到文件夾追加到列表中,pop是刪除最后一位的元素,每次又遍歷最后一位的文件夾,所以每一輪都會將次級目錄下的文件夾遍歷完成之后再遍歷下個次級目錄
import os
def get_files(path):
# 判斷路徑是否存在
if not os.path.exists(path):
print('路徑不存在')
return
if not os.path.isdir(path):
print('路徑是一個文件夾')
return
# 創建一個列表作為棧
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 os
import collections
def 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()
# 獲取目錄下的所有內容
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 遍歷磁盤目錄的三種方法的詳細內容,更多關于python 遍歷磁盤目錄的資料請關注腳本之家其它相關文章!
您可能感興趣的文章:- 用python監控服務器的cpu,磁盤空間,內存,超過郵件報警
- python實現磁盤日志清理的示例
- python獲取磁盤號下盤符步驟詳解
- 使用python獲取電腦的磁盤信息方法
- python3實現磁盤空間監控
- python3監控CentOS磁盤空間腳本
- 磁盤垃圾文件清理器python代碼實現
- Python實現獲取磁盤剩余空間的2種方法
- Linux 發郵件磁盤空間監控(python)
- Python實現測試磁盤性能的方法