张赐荣 | Python 递归算法: 列举文件和文件夹

在开始之前,先来了解一下递归算法。
递归是一种算法设计技巧,可以递归地处理文件夹和文件,使用 Python 的 os 模块中的 os.listdir() 和 os.path.isdir() 函数可以方便地实现递归处理。

首先,我们需要使用 Python 的 os 模块来访问文件系统。os 模块提供了很多有用的函数,其中之一是 os.listdir(),它可以返回给定文件夹中的文件列表。
所以,我们可以使用以下代码来列出给定文件夹中的所有文件:
import os
def list_files(folder):
# 获取文件夹中的文件列表
files = os.listdir(folder)
# 遍历文件列表
for file in files:
# 输出文件名
print(file)
# 调用函数,列出当前文件夹中的所有文件
list_files('.')
这段代码中的 '.' 表示当前文件夹。
现在,我们来看看如何递归文件夹。
我们可以在上面的函数中添加一个循环,用来处理文件夹中的每一个文件。如果遇到一个文件夹,我们可以再次调用 list_files() 函数来处理这个文件夹。这样,我们就可以递归处理文件夹了。
下面是完整的代码:
import os
def list_files(folder):
# 获取文件夹中的文件列表
files = os.listdir(folder)
# 遍历文件列表
for file in files:
# 如果是文件夹,则递归处理
if os.path.isdir(file):
list_files(file)
# 否则,输出文件名
else:
print(file)
# 调用函数,列出当前文件夹及其子文件夹中的所有文件
list_files('.')
这段代码中的 os.path.isdir() 函数用来判断给定的路径是否是一个文件夹。如果是,就递归处理这个文件夹;否则,就输出文件名。
好了,现在你已经学会了如何使用 Python 递归文件夹和文件。希望这篇教程对你有帮助。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值