废话不多说,直接上代码
import os# 第一种方式def recu_List_dirs_by_dictionary_order(path,indent = 0,maxi = -1): ''' 按字典序递归输出目录结构 :param path: str 文件路径 :param indent: int 首次缩进空格(默认为 0,一般不用改变) :param maxi: int 最大展开层数(默认为 -1,表示全部展开) ''' if maxi != 0: try: lsdir = os.Listdir(path) except PermissionError: # 对于权限不够的文件不作处理 pass else: for item in lsdir: full_path = os.path.join(path,item) if os.path.isdir(full_path): print(' ' * indent,'+',item) recu_List_dirs_by_dictionary_order(full_path,indent + 4,maxi - 1) if os.path.isfile(full_path): print(' ' * indent,'-',item)# 第二种方式def recu_List_dirs_by_file_type(path,maxi = -1): ''' 按文件类型递归输出目录结构 :param path: str 文件路径 :param indent: int 首次缩进空格(默认为 0,一般不用改变) :param maxi: int 最大展开层数(默认为 -1,表示全部展开) ''' if maxi != 0: try: lsdir = os.Listdir(path) except PermissionError: # 对于权限不够的文件不作处理 pass else: dirs = [item for item in lsdir if os.path.isdir(os.path.join(path,item))] files = [item for item in lsdir if os.path.isfile(os.path.join(path,item))] for item in dirs: print(' ' * indent,item) recu_List_dirs_by_file_type(os.path.join(path,item),maxi - 1) for item in files: print(' ' * indent,item)if __name__ == '__main__': file_path = input('请输入路径:') print('\n---按字典序递归输出目录结构---') recu_List_dirs_by_dictionary_order(file_path,2) print('\n---按文件类型递归输出目录结构---') recu_List_dirs_by_file_type(file_path,2)
效果如下
请输入路径:D:\Blog\source---按字典序递归输出目录结构--- + about + index - index.md + archives + index - index.md + categorIEs + index - index.md + images - avatar.jpg + Tags + index - index.md + _posts + Hexo系列(一) 搭建博客网站 - Hexo系列(一) 搭建博客网站.md - Hexo系列(三) 常用命令详解.md - Hexo系列(二) 配置文件详解.md - Hexo系列(五) 撰写文章.md - Hexo系列(四) NexT主题配置.md - linux学习笔记(一) 文件系统.md - linux学习笔记(七) 查询系统.md - linux学习笔记(二) 文件管理.md - linux学习笔记(五) 账号管理.md - linux学习笔记(六) 进程管理.md - linux学习笔记(四) vi编辑器.md - liunx学习笔记(三) 文件权限.md - Python学习笔记(一) 列表和元组.md - Python学习笔记(七) 异常处理.md - Python学习笔记(三) 字典.md + Python学习笔记(九) map、zip和filter函数 - Python学习笔记(九) map、zip和filter函数.md - Python学习笔记(二) 字符串.md - Python学习笔记(五) 类与对象.md - Python学习笔记(八) 文件处理.md - Python学习笔记(六) 模块与包.md - Python学习笔记(十) 生成器、迭代器和装饰器.md + Python学习笔记(四) 函数 - Python学习笔记(四) 函数.md - React学习笔记(一) 入门.md - React学习笔记(七) React Router.md - React学习笔记(三) 事件处理与表单元素.md - React学习笔记(二) 组件.md - React学习笔记(五) 状态提升.md - React学习笔记(六) Create React App.md - React学习笔记(四) 条件渲染与列表渲染.md - React学习笔记.md - Vue学习笔记(一) 入门.md - Vue学习笔记(七) 组件.md - Vue学习笔记(三) 计算属性和侦听属性.md - Vue学习笔记(九) Vue Cli.md - Vue学习笔记(二) 模板语法.md - Vue学习笔记(五) 样式绑定和事件处理.md - Vue学习笔记(八) 组件进阶.md - Vue学习笔记(六) 表单输入绑定.md - Vue学习笔记(十) Vue Router.md - Vue学习笔记(十一) Vuex.md - Vue学习笔记(十二) Vue AJAX.md - Vue学习笔记(四) 条件渲染和列表渲染.md - Vue学习笔记.md + 微信小程序(一) 入门 - 微信小程序(一) 入门.md - 效率系列(一) Chrome常用快捷键.md + 效率系列(三) Chrome实用插件 - 效率系列(三) Chrome实用插件.md - 效率系列(二) Win10常用快捷键.md - 效率系列(五) VScode常用快捷键.md + 效率系列(六) Chrome调试技巧 - 效率系列(六) Chrome调试技巧.md - 效率系列(四) VS常用快捷键.md + 爬虫实战(一) 用Python爬取百度百科 - 爬虫实战(一) 用Python爬取百度百科.md + 爬虫实战(三) 用Python爬取拉勾网 - 爬虫实战(三) 用Python爬取拉勾网.md + 爬虫实战(二) 用Python爬取网易云歌单 - 爬虫实战(二) 用Python爬取网易云歌单.md + 爬虫系列(一) 网络爬虫简介 - 爬虫系列(一) 网络爬虫简介.md - 爬虫系列(七) requests的基本使用.md - 爬虫系列(三) urllib的基本使用.md - 爬虫系列(九) xpath的基本使用.md + 爬虫系列(二) Chrome抓包分析 - 爬虫系列(二) Chrome抓包分析.md - 爬虫系列(五) re的基本使用.md + 爬虫系列(八) 用requests实现天气查询 - 爬虫系列(八) 用requests实现天气查询.md + 爬虫系列(六) 用urllib和re爬取百度贴吧 - 爬虫系列(六) 用urllib和re爬取百度贴吧.md + 爬虫系列(十) 用requests和xpath爬取豆瓣电影 - 爬虫系列(十) 用requests和xpath爬取豆瓣电影.md + 爬虫系列(十一) 用requests和xpath爬取豆瓣电影评论 - 爬虫系列(十一) 用requests和xpath爬取豆瓣电影评论.md + 爬虫系列(十三) 用selenium爬取京东商品 - 爬虫系列(十三) 用selenium爬取京东商品.md - 爬虫系列(十二) selenium的基本使用.md + 爬虫系列(四) 用urllib实现英语翻译 - 爬虫系列(四) 用urllib实现英语翻译.md---按文件类型递归输出目录结构--- + about + index - index.md + archives + index - index.md + categorIEs + index - index.md + images - avatar.jpg + Tags + index - index.md + _posts + Hexo系列(一) 搭建博客网站 + Python学习笔记(九) map、zip和filter函数 + Python学习笔记(四) 函数 + 微信小程序(一) 入门 + 效率系列(三) Chrome实用插件 + 效率系列(六) Chrome调试技巧 + 爬虫实战(一) 用Python爬取百度百科 + 爬虫实战(三) 用Python爬取拉勾网 + 爬虫实战(二) 用Python爬取网易云歌单 + 爬虫系列(一) 网络爬虫简介 + 爬虫系列(二) Chrome抓包分析 + 爬虫系列(八) 用requests实现天气查询 + 爬虫系列(六) 用urllib和re爬取百度贴吧 + 爬虫系列(十) 用requests和xpath爬取豆瓣电影 + 爬虫系列(十一) 用requests和xpath爬取豆瓣电影评论 + 爬虫系列(十三) 用selenium爬取京东商品 + 爬虫系列(四) 用urllib实现英语翻译 - Hexo系列(一) 搭建博客网站.md - Hexo系列(三) 常用命令详解.md - Hexo系列(二) 配置文件详解.md - Hexo系列(五) 撰写文章.md - Hexo系列(四) NexT主题配置.md - linux学习笔记(一) 文件系统.md - linux学习笔记(七) 查询系统.md - linux学习笔记(二) 文件管理.md - linux学习笔记(五) 账号管理.md - linux学习笔记(六) 进程管理.md - linux学习笔记(四) vi编辑器.md - liunx学习笔记(三) 文件权限.md - Python学习笔记(一) 列表和元组.md - Python学习笔记(七) 异常处理.md - Python学习笔记(三) 字典.md - Python学习笔记(九) map、zip和filter函数.md - Python学习笔记(二) 字符串.md - Python学习笔记(五) 类与对象.md - Python学习笔记(八) 文件处理.md - Python学习笔记(六) 模块与包.md - Python学习笔记(十) 生成器、迭代器和装饰器.md - Python学习笔记(四) 函数.md - React学习笔记(一) 入门.md - React学习笔记(七) React Router.md - React学习笔记(三) 事件处理与表单元素.md - React学习笔记(二) 组件.md - React学习笔记(五) 状态提升.md - React学习笔记(六) Create React App.md - React学习笔记(四) 条件渲染与列表渲染.md - React学习笔记.md - Vue学习笔记(一) 入门.md - Vue学习笔记(七) 组件.md - Vue学习笔记(三) 计算属性和侦听属性.md - Vue学习笔记(九) Vue Cli.md - Vue学习笔记(二) 模板语法.md - Vue学习笔记(五) 样式绑定和事件处理.md - Vue学习笔记(八) 组件进阶.md - Vue学习笔记(六) 表单输入绑定.md - Vue学习笔记(十) Vue Router.md - Vue学习笔记(十一) Vuex.md - Vue学习笔记(十二) Vue AJAX.md - Vue学习笔记(四) 条件渲染和列表渲染.md - Vue学习笔记.md - 微信小程序(一) 入门.md - 效率系列(一) Chrome常用快捷键.md - 效率系列(三) Chrome实用插件.md - 效率系列(二) Win10常用快捷键.md - 效率系列(五) VScode常用快捷键.md - 效率系列(六) Chrome调试技巧.md - 效率系列(四) VS常用快捷键.md - 爬虫实战(一) 用Python爬取百度百科.md - 爬虫实战(三) 用Python爬取拉勾网.md - 爬虫实战(二) 用Python爬取网易云歌单.md - 爬虫系列(一) 网络爬虫简介.md - 爬虫系列(七) requests的基本使用.md - 爬虫系列(三) urllib的基本使用.md - 爬虫系列(九) xpath的基本使用.md - 爬虫系列(二) Chrome抓包分析.md - 爬虫系列(五) re的基本使用.md - 爬虫系列(八) 用requests实现天气查询.md - 爬虫系列(六) 用urllib和re爬取百度贴吧.md - 爬虫系列(十) 用requests和xpath爬取豆瓣电影.md - 爬虫系列(十一) 用requests和xpath爬取豆瓣电影评论.md - 爬虫系列(十三) 用selenium爬取京东商品.md - 爬虫系列(十二) selenium的基本使用.md - 爬虫系列(四) 用urllib实现英语翻译.md总结
以上是内存溢出为你收集整理的【Python】递归输出目录结构全部内容,希望文章能够帮你解决【Python】递归输出目录结构所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)