Python实战笔记(一) 递归输出目录结构
废话不多说,直接上代码
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, 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:
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), indent + 4, 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, 0, 2)
print('\n---按文件类型递归输出目录结构---')
recu_list_dirs_by_file_type(file_path, 0, 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学习笔记 】
版权声明:本博客属于个人维护博客,未经博主允许不得转载其中文章。