递归和我们之前所用的循环差不多是一个概念。
在完成如上要求,我们先来了解 python中 OS 中的几个方法:
代码语言:javascript复制In [1]: import os
In [3]: os.listdir('/tmp') ##列出/tmp目录中所有的文件
Out[3]: ##以列表的方式展示
['yum.log',
'.X11-unix',
'.ICE-unix',
'.font-unix',
'.Test-unix',
'.XIM-unix',
'ks-script-DyWDiv',
In [4]: os.listdir('.') ##列出当前目录下的文件
Out[4]:
['.bash_logout',
'.bash_profile',
'.bashrc',
'.cshrc',
'.tcshrc',
'anaconda-ks.cfg',
'.bash_history',
In [5]: os.path.isdir('/tmp') ##判断括号内的参数是不是一个 目录
Out[5]: True
In [6]: os.path.isfile('/tmp') ##判断元素是否为文件
Out[6]: False
In [7]: os.path.isfile('/etc/passwd')
Out[7]: True
In [8]: os.path.join('/etc/','passwd') ##join这个方法是连接两个目录的
Out[8]: '/etc/passwd'
In [9]: os.path.join('/etc/','passwd','abc')
Out[9]: '/etc/passwd/abc'
递归列出目录里面的文件:
代码语言:javascript复制#!/usr/bin/python
import os
import sys
def print_files(path) ##定义一个函数
lsdir = os.listdir(path) ##列出指定路径中的文件 目录
dirs = [i for i in lsdir if os.path.isdir(os.path.join(path, i))] ##列表重写的方式判断,如果这是一个目录,我们需要判断是否有二级目录并使用join连接一级级的目录
files = [i for i in lsdir if os.path.isfile(os.path.join(path, i)] ##列表重写的方式判断,如果是一个文件,使用join把文件链接起来
if files: ##如果是文件
for f in files: ##如上输出的是一个文件的列表,我们需要把它组合并打印出来如下:
print os.path.join(path, f)
if dirs:
for d in dirs: ##循环一下目录,因为说不定会有很多目录,我们需要一直对这个目录进行递归查找文件,就会频繁的递归调用 print_files(path)
print_files(os.path.join(path, d))
print_files(sys.argv[1]) ##程序的入口,并使用sys.argv接收一个参数