鱼C论坛

 找回密码
 立即注册
查看: 1352|回复: 2

[已解决]为什么我这个代码他会报错说超过了最大递归深度呢?

[复制链接]
发表于 2022-3-5 12:06:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

  1. #编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径
  2. import os
  3. vedio_list = list()
  4. def vedio_file(start_file):
  5.     os.chdir(start_file)
  6.     for each_file in os.listdir(os.curdir):
  7.         ext = os.path.splitext(each_file)[1]
  8.         if ext in ['.mp4','.rmvb','.avi']:
  9.             file_dir = os.getcwd()+os.sep()+each_file+os.linesep
  10.             vedio_list.append(file_dir)
  11.         if os.path.isdir(each_file):
  12.             vedio_file(start_file) #递归调用
  13.             os.chdir(os.pardir)
  14.     program_dir = os.getcwd()
  15.     dir_file = open('vedioList.txt', 'w')
  16.     for each_dir in vedio_list:
  17.         dir_file.writelinees(each_dir)
  18.         dir_file.close()


  19. start_file = input('请输入要查找的目录:')
  20. vedio_file(start_file)
复制代码


为什么我这个代码他会报错说超过了最大递归深度呢?
最佳答案
2022-3-5 12:12:09
本帖最后由 isdkz 于 2022-3-5 12:27 编辑

因为你每次递归都是传的 start_file,导致无限递归了

  1. #编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径
  2. import os
  3. vedio_list = []                          # 这里直接用 [] 即可,没必要用 list()
  4. def vedio_file(start_file):
  5.     os.chdir(start_file)
  6.     for each_file in os.listdir(os.curdir):
  7.         ext = os.path.splitext(each_file)[1]
  8.         if ext in ['.mp4','.rmvb','.avi']:
  9.             file_dir = os.getcwd()+os.sep+each_file+os.linesep   # 这里的 os.sep() 改成 os.sep,os.sep 是一个表示路径分隔符的字符串,不是函数
  10.             vedio_list.append(file_dir)
  11.         if os.path.isdir(each_file):
  12.             vedio_file(each_file) #递归调用              这里换成each_file
  13.             os.chdir(os.pardir)
  14.     # program_dir = os.getcwd()        这一行去掉,多余的操作



  15. start_file = input('请输入要查找的目录:')
  16. vedio_file(start_file)

  17. # 这一部分得放在函数外,因为你的函数在递归,还没得出结果,不要在递归函数里面做太多其它操作
  18. dir_file = open('vedioList.txt', 'w')
  19. for each_dir in vedio_list:
  20.     dir_file.writelines(each_dir)
  21. dir_file.close()                          # 这里不能缩进在 for 循环里面,你把文件给关闭了,第二次循环还怎么写进文件
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-3-5 12:12:09 | 显示全部楼层    本楼为最佳答案   
本帖最后由 isdkz 于 2022-3-5 12:27 编辑

因为你每次递归都是传的 start_file,导致无限递归了

  1. #编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径
  2. import os
  3. vedio_list = []                          # 这里直接用 [] 即可,没必要用 list()
  4. def vedio_file(start_file):
  5.     os.chdir(start_file)
  6.     for each_file in os.listdir(os.curdir):
  7.         ext = os.path.splitext(each_file)[1]
  8.         if ext in ['.mp4','.rmvb','.avi']:
  9.             file_dir = os.getcwd()+os.sep+each_file+os.linesep   # 这里的 os.sep() 改成 os.sep,os.sep 是一个表示路径分隔符的字符串,不是函数
  10.             vedio_list.append(file_dir)
  11.         if os.path.isdir(each_file):
  12.             vedio_file(each_file) #递归调用              这里换成each_file
  13.             os.chdir(os.pardir)
  14.     # program_dir = os.getcwd()        这一行去掉,多余的操作



  15. start_file = input('请输入要查找的目录:')
  16. vedio_file(start_file)

  17. # 这一部分得放在函数外,因为你的函数在递归,还没得出结果,不要在递归函数里面做太多其它操作
  18. dir_file = open('vedioList.txt', 'w')
  19. for each_dir in vedio_list:
  20.     dir_file.writelines(each_dir)
  21. dir_file.close()                          # 这里不能缩进在 for 循环里面,你把文件给关闭了,第二次循环还怎么写进文件
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-5 12:32:58 | 显示全部楼层
isdkz 发表于 2022-3-5 12:12
因为你每次递归都是传的 start_file,导致无限递归了

我懂了,感谢,最开始调用递归的时候我确实用的each_file,后来不知道咋改成start_file了,我主要的错误好像就是读写文件哪那里,非常感谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-30 05:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表