Python学习从0到1 day28 Python 高阶技巧 ⑧ 递归

那就祝我们爬不同的山,还能回到同一条路上,不是时时见面,但是时时惦记之人

------ 24.11.13

递归

1.什么是递归

递归在编程中是一种非常重要的算法

递归:即方法(函数)自己调用自己的一种特殊编程写法

函数调用自己,即称之为递归调用

2.递归需要注意什么?

① 注意退出的条件,否则容易变成无限递归

② 注意返回值的传递,确保从最内层,层层传递到最外层

3.os模块的3个方法

os.listdir列出指定目录下的内容

os.path.isdir 判断给定路径是否是文件夹,是返回True,否则返回False

os.path.exists判断给定路径是否存在,存在返回True,否则返回False

4.案例 ------ 递归查找文件

最典型的递归场景为找出一个文件夹中全部的文件。

如图,在文件夹内,有如下嵌套结构和所属的文件,可以通过递归编程的形式完成

文件夹:

------切

------都

------会

------好

------的

------信.txt

------相.txt

------直.txt

------一.txt

我.txt

python 复制代码
'''
演示Python递归操作
需求:通过递归,找出一个指定文件夹内的全部文件
思路:写一个函数,列出文件夹内的全部内容,如果是文件就收集到list
    如果是文件夹,就递归调用自己,再次判断。
'''
import os

'''
    os.listdir      列出文件夹中所有文件
    os.path.isdir        判断路径是否是文件夹
    os.path.exists  判断路径是否存在
'''

def get_files_recursion_from_dir(path):
    '''
    从指定的文件夹中使用递归方式,获取全部的文件列表
    :param path:倍判断的文件夹
    :return:list 包含全部的文件,如果目录不存在或者无文件就返回一个空list
    '''
    file_list = []
    if os.path.exists(path):
        for file in os.listdir(path):
            new_path = path + "/" + file
            if os.path.isdir(new_path):
                file_list += get_files_recursion_from_dir(new_path)
            else:
                file_list.append(new_path)
    else:
        print("你输入的路径有误,文件不存在")
        return []

    return file_list

if __name__ == '__main__':
    print(get_files_recursion_from_dir("E:\python.learning\一"))
相关推荐
Summer_Uncle23 分钟前
【C++学习】指针
c++·学习
光影少年1 小时前
AIGG人工智能生态及学习路线和应用领域
人工智能·学习
递归不收敛1 小时前
多模态学习大纲笔记(未完成)
人工智能·笔记·学习·自然语言处理
FPGA-李宇航2 小时前
FPGA中,“按键控制LED灯实验”学习中常见问题、解决思路和措施以及经验总结!!!(新手必看)
学习·fpga开发·按键控制led灯
正经教主3 小时前
【Trae+AI】和Trae学习搭建App_01:项目架构设计与环境搭建
学习·app
普蓝机器人3 小时前
面向智慧农业的自主移动果蔬采摘机器人:融合视觉识别与自动驾驶的智能化农作系统研究
人工智能·学习·机器人·移动机器人·三维仿真导航
lazily-c4 小时前
Web后端开发总结
java·学习·web·1024程序员节
于顾而言6 小时前
【笔记】Comprehensive Rust语言学习
笔记·学习·rust
im_AMBER7 小时前
React 06
前端·javascript·笔记·学习·react.js·前端框架
zyq99101_18 小时前
树与二叉树的奥秘全解析
c语言·数据结构·学习·1024程序员节