鱼C论坛

 找回密码
 立即注册
查看: 1619|回复: 3

[技术交流] 遍历目录(递归遍历,栈深度遍历,队列广度遍历)

[复制链接]
发表于 2019-2-27 14:35:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Stubborn 于 2019-4-3 20:50 编辑

递归遍历:
import os
def search_file(start_dir, sp=""):
    os.chdir(start_dir)
    sp += "   "
    for each_file in os.listdir(os.curdir):
        if os.path.isdir(each_file):
            print(sp+"目录:"+os.getcwd() + os.sep + each_file)
            search_file(each_file, sp)  
            os.chdir(os.pardir)  
        else:
            print(sp+"文件:"+os.getcwd() + os.sep + each_file)

start_dir = r"C:\Users\Administrator\Desktop"
search_file(start_dir)

栈深度遍历(先进后出),遍历目录不懂👇提问
import os

def get_all_dir_deep(path):
    stack = [] 
    stack.append(path)
    while len(stack) !=0:
        dirpath = stack.pop()
        fileslist = os.listdir(dirpath)
        for filename in fileslist:
            fileabspath = os.path.join(dirpath,filename)
            if os.path.isdir(fileabspath):
                print("目录:",filename)
                stack.append(fileabspath)
            else:
                print("普通文件:",filename)

path = "/Users/sstubborn/Desktop"
get_all_dir_deep(path)

队列广度遍历,先进先出
import os
import collections

def get_all_dir_queue(path):
    queue = collections.deque() #建队列
    queue.append(path)

    #处理队列,当队列为空结束循环
    while len(queue) !=0:
        dirpath = queue.popleft()
        fileslist = os.listdir(dirpath)

        for filename in fileslist:
            fileabspath = os.path.join(dirpath,filename)
            if os.path.isdir(fileabspath):
                print("目录:",filename)
                queue.append(fileabspath)
            else:
                print("普通文件:",filename)

path = "/Users/sstubborn/Desktop"
get_all_dir_queue(path)

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 20:21:18 | 显示全部楼层
你这是啥不懂
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-2-27 22:56:02 | 显示全部楼层

三种模式打印历遍指定的文件目录而已大神有哪里不懂需要解释的  递归还有点问题,你也懂反正,看看哪里错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-27 22:39:48 | 显示全部楼层
这个没啥问题吧,看着逻辑挺对的,运行结果也满足要求
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 13:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表