python递归列出目录及其子目录下所有文件
一、前言
函数的递归,简单来说,就是函数内部调用自己
先举个小例子,求阶乘
1 def factorial(n): 2 if n == 0: 3 return 1 4 else: 5 return n * factorial(n-1)
递归要注意两个事项:
1、必须要有最后的默认结果,也就是最底层目录的默认结果
if n == 0
2、递归参数必须向默认结果收敛
factorial(n-1)
要用到 os 模块下的几个方法
要用到 os 模块下的几个方法
二、递归列出目录里的文件(包括子目录,类似 linux下的find)
ps : 这个代码对运维来说值得一学,反正我是觉得 python 颇强大的, 刚学,大家不喜勿喷 *_*
要用到 os 模块下的几个方法
import os
1、os.listdir('/root/python/') #列出当前目录下所有文件
2、os.path.isdir('/abc') #判断是否是目录,返回布尔值,不存在也返回false
3、os.path.isfile('/etc/passwd') #判断是否是文件
4、os.path.join('/etc/', 'passwd') #连接文件,返回/etc/passwd
1 #!/usr/bin/python 2 3 import os 4 import sys 5 6 def print_files(path): 7 lsdir = os.listdir(path) 8 dirs = [i for i in lsdir if os.path.isdir(os.path.join( 9 path, i))] 10 if dirs: 11 for i in dirs: 12 print_files(os.path.join(path, i)) 13 files = [i for i in lsdir if os.path.isfile(os.path.joi 14 n(path,i))] 15 for f in files: 16 print os.path.join(path, f) 17 18 print_files(sys.argv[1])
简单解说下:
lsdir 列出当前目录所有东西(文件+目录)
dirs 返回当前目录(path)下的所有目录(不含子目录)
for i in dirs: 是 dirs目录下的下一个子目录,不断递归到最后一层
最后到达最深那层目录,打印所有文件 files
注意:os.path.join 要进行连接操作的,我们需要完整目录,不是相对目录
三、调用及返回结果
python test.py /root/python
返回结果