python 遍歷磁盤目錄的三種方法

深度遍歷

遞歸

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 遍歷磁盤目錄的資料請關註WalkonNet其它相關文章!

推薦閱讀:

    None Found