结论:使用递归时,递归会一层一层的进去,最后一个递归运行结束后,会一层一层的出来。并且出来后会继续运行被递归分割的代码。
递归出来可以做什么:python使用 os 模块,删除非空目录,会抛出?OSError 异常,所以就需要将文件夹里的文件全部删除后,再删除目录。递归出来时,说明文件已经被删除,这已经是一个空目录。所以在递归出来时可以进行删除目录操作
演示代码:
@staticmethod
def del_dir(dirPath):
'''
删除目录,需要用到递归,先删除目录里面的文件,把文件删除后,再删除空目录
:param dirPath:
:return:
'''
# 判断是否是目录
if os.path.isdir(dirPath):
# 拿到文件列表
fileList = os.listdir(dirPath)
# 如果文件列表不为空,进行进行遍历和删除操作
if fileList:
for file in fileList:
# 拼接路径
filePath = os.path.join(dirPath, file)
# 判断是否是文件,如果是,删除文件
if os.path.isfile(filePath):
os.remove(filePath)
# 判断是否是目录,如果是,进行递归
elif os.path.isdir(filePath):
print('{}:我进来了'.format(filePath))
Catalogue.del_dir(filePath)
# ---- 递归结束后会执行以下代码 ----
# 递归进去文件夹后还会再出来,出来时执行此代码
os.rmdir(dirPath)
print('{}:我出来了'.format(dirPath))
else:
# 如果目录为空,直接删除根目录
os.rmdir(dirPath)
# 判断是否是文件夹,如果是,那么说明删除失败,返回 False
if os.path.isdir(dirPath):
return False
return True
?运行结果:
图解:
?
?
?
|