jimihuahua 发表于 2020-8-1 13:24:22

在学习课后题的时候碰到的问题,求解答

3. 编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径,程序实现如图:

import os

def search_file(start_dir, target) :
    os.chdir(start_dir)
   
    for each_file in os.listdir(os.curdir) :
      ext = os.path.splitext(each_file)
      if ext in target :
            vedio_list.append(os.getcwd() + os.sep + each_file + os.linesep) # 使用os.sep是程序更标准
      if os.path.isdir(each_file) :
            search_file(each_file, target) # 递归调用
            os.chdir(os.pardir) # 递归调用后切记返回上一层目录

start_dir = input('请输入待查找的初始目录:')
program_dir = os.getcwd()

target = ['.mp4', '.avi', '.rmvb']
vedio_list = []

search_file(start_dir, target)

f = open(program_dir + os.sep + 'vedioList.txt', 'w')
f.writelines(vedio_list)
f.close()



在以上的课后题中,里面提到了
      if os.path.isdir(each_file) :
            search_file(each_file, target) # 递归调用
            os.chdir(os.pardir) # 递归调用后切记返回上一层目录

调用递归的方式,然后注释中写了递归调用后要返回上一层目录,从直觉上第一感觉就觉得应该有这一步,但是想不明白为什么要返回上一层目录
能帮忙解构一下中间的逻辑吗?

zltzlt 发表于 2020-8-1 13:26:17

如果不返回上一步,程序就陷在子目录里出不来了

Twilight6 发表于 2020-8-1 13:29:33

本帖最后由 Twilight6 于 2020-8-1 13:31 编辑




你打开了一个目录如果不返回那么就会导致遗漏查找原来目录的其他文件夹

比如你根目录文件夹有两个,只要打开其中一个文件夹,如果不会在查找完文件后返回

那么就不会回去查找根目录下的另一个文件夹,就是因为你没有返回上层目录

页: [1]
查看完整版本: 在学习课后题的时候碰到的问题,求解答