Python os.walk的用法与举例

本文详细介绍了Python中os.walk()函数的用法,并通过实例展示了如何利用此函数递归遍历目录结构来获取文件夹及文件列表。文章提供了三种不同方式的代码示例,帮助读者更好地理解和使用os.walk()。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载:http://blog.youkuaiyun.com/bagboy_taobao_com/article/details/8938126


os.walk(top, topdown=True, onerror=None, followlinks=False) 

可以得到一个三元tupple(dirpath, dirnames, filenames), 

第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。

dirpath 是一个string,代表目录的路径,

dirnames 是一个list,包含了dirpath下所有子目录的名字。

filenames 是一个list,包含了非目录文件的名字。

这些名字不包含路径信息,如果需要得到全路径,需要使用os.path.join(dirpath, name).

通过for循环自动完成递归枚举

例如:

F:\aaa 目录是这样的文件目录结构

F:\aaa

|--------1.txt

|--------2.txt

|--------3.txt

|--------4

         |-------5.txt

         |-------6.txt

         |-------7.txt


[python]  view plain  copy
  1. #!/usr/bin/env python  
  2. # 2.py  
  3. # use UTF-8  
  4. # Python 3.3.0  
  5.   
  6. # os.walk()的使用  
  7. import os  
  8.   
  9. # 枚举dirPath目录下的所有文件  
  10.   
  11. def main():  
  12. #begin  
  13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
  14.     for root, dirs, files in os.walk(fileDir):  
  15.     #begin  
  16.         print(root)  
  17.         print(dirs)  
  18.         print(files)  
  19.     #end  
  20.     os.system("pause")  
  21. #end  
  22.   
  23. if __name__ == '__main__':  
  24. #begin  
  25.     main()  
  26. #end  
  27.   
  28.   
  29. # 输出  
  30. # F:\aaa  
  31. # ['4']  
  32. # ['1.txt', '2.txt', '3.txt']  
  33. # F:\aaa\4  
  34. # []  
  35. # ['5.txt', '6.txt', '7.txt']  

你也可以这样

[python]  view plain  copy
  1. #!/usr/bin/env python  
  2. # 3.py  
  3. # use UTF-8  
  4. # Python 3.3.0  
  5.   
  6. # os.walk()的使用  
  7. import os  
  8.   
  9. # 枚举dirPath目录下的所有文件  
  10.   
  11. def main():  
  12. #begin  
  13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
  14.     for a in os.walk(fileDir):  
  15.     #begin  
  16.         print(a[0])  
  17.         print(a[1])  
  18.         print(a[2])  
  19.     #end  
  20.     os.system("pause")  
  21. #end  
  22.   
  23. if __name__ == '__main__':  
  24. #begin  
  25.     main()  
  26. #end  
  27.   
  28.   
  29. # 输出  
  30. # F:\aaa  
  31. # ['4']  
  32. # ['1.txt', '2.txt', '3.txt']  
  33. # F:\aaa\4  
  34. # []  
  35. # ['5.txt', '6.txt', '7.txt']  

通过for循环即可完成目录的递归.


你还可以这样

[python]  view plain  copy
  1. #!/usr/bin/env python  
  2. # 2.py  
  3. # use UTF-8  
  4. # Python 3.3.0  
  5.   
  6. # os.walk()的使用  
  7. import os  
  8.   
  9. # 枚举dirPath目录下的所有文件  
  10.   
  11. def main():  
  12. #begin  
  13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
  14.     for root, dirs, files in os.walk(fileDir):  
  15.     #begin  
  16.         for dir in dirs:  
  17.         #begin  
  18.             print(os.path.join(root, dir))  
  19.         #end  
  20.         for file in files:  
  21.         #begin  
  22.             print(os.path.join(root, file))  
  23.         #end  
  24.     #end  
  25.     os.system("pause")  
  26. #end  
  27.   
  28. if __name__ == '__main__':  
  29. #begin  
  30.     main()  
  31. #end  
  32.   
  33.   
  34. # 输出  
  35. # F:\aaa\4  
  36. # F:\aaa\1.txt  
  37. # F:\aaa\2.txt  
  38. # F:\aaa\3.txt  
  39. # F:\aaa\4\5.txt  
  40. # F:\aaa\4\6.txt  
  41. # F:\aaa\4\7.txt  os.walk(top, topdown=True, onerror=None, followlinks=False) 

    可以得到一个三元tupple(dirpath, dirnames, filenames), 

    第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。

    dirpath 是一个string,代表目录的路径,

    dirnames 是一个list,包含了dirpath下所有子目录的名字。

    filenames 是一个list,包含了非目录文件的名字。

    这些名字不包含路径信息,如果需要得到全路径,需要使用os.path.join(dirpath, name).

    通过for循环自动完成递归枚举

    例如:

    F:\aaa 目录是这样的文件目录结构

    F:\aaa

    |--------1.txt

    |--------2.txt

    |--------3.txt

    |--------4

             |-------5.txt

             |-------6.txt

             |-------7.txt


    [python]  view plain  copy
    1. #!/usr/bin/env python  
    2. # 2.py  
    3. # use UTF-8  
    4. # Python 3.3.0  
    5.   
    6. # os.walk()的使用  
    7. import os  
    8.   
    9. # 枚举dirPath目录下的所有文件  
    10.   
    11. def main():  
    12. #begin  
    13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
    14.     for root, dirs, files in os.walk(fileDir):  
    15.     #begin  
    16.         print(root)  
    17.         print(dirs)  
    18.         print(files)  
    19.     #end  
    20.     os.system("pause")  
    21. #end  
    22.   
    23. if __name__ == '__main__':  
    24. #begin  
    25.     main()  
    26. #end  
    27.   
    28.   
    29. # 输出  
    30. # F:\aaa  
    31. # ['4']  
    32. # ['1.txt', '2.txt', '3.txt']  
    33. # F:\aaa\4  
    34. # []  
    35. # ['5.txt', '6.txt', '7.txt']  

    你也可以这样

    [python]  view plain  copy
    1. #!/usr/bin/env python  
    2. # 3.py  
    3. # use UTF-8  
    4. # Python 3.3.0  
    5.   
    6. # os.walk()的使用  
    7. import os  
    8.   
    9. # 枚举dirPath目录下的所有文件  
    10.   
    11. def main():  
    12. #begin  
    13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
    14.     for a in os.walk(fileDir):  
    15.     #begin  
    16.         print(a[0])  
    17.         print(a[1])  
    18.         print(a[2])  
    19.     #end  
    20.     os.system("pause")  
    21. #end  
    22.   
    23. if __name__ == '__main__':  
    24. #begin  
    25.     main()  
    26. #end  
    27.   
    28.   
    29. # 输出  
    30. # F:\aaa  
    31. # ['4']  
    32. # ['1.txt', '2.txt', '3.txt']  
    33. # F:\aaa\4  
    34. # []  
    35. # ['5.txt', '6.txt', '7.txt']  

    通过for循环即可完成目录的递归.


    你还可以这样

    [python]  view plain  copy
    1. #!/usr/bin/env python  
    2. # 2.py  
    3. # use UTF-8  
    4. # Python 3.3.0  
    5.   
    6. # os.walk()的使用  
    7. import os  
    8.   
    9. # 枚举dirPath目录下的所有文件  
    10.   
    11. def main():  
    12. #begin  
    13.     fileDir = "F:" + os.sep + "aaa"     # 查找F:\aaa 目录下    
    14.     for root, dirs, files in os.walk(fileDir):  
    15.     #begin  
    16.         for dir in dirs:  
    17.         #begin  
    18.             print(os.path.join(root, dir))  
    19.         #end  
    20.         for file in files:  
    21.         #begin  
    22.             print(os.path.join(root, file))  
    23.         #end  
    24.     #end  
    25.     os.system("pause")  
    26. #end  
    27.   
    28. if __name__ == '__main__':  
    29. #begin  
    30.     main()  
    31. #end  
    32.   
    33.   
    34. # 输出  
    35. # F:\aaa\4  
    36. # F:\aaa\1.txt  
    37. # F:\aaa\2.txt  
    38. # F:\aaa\3.txt  
    39. # F:\aaa\4\5.txt  
    40. # F:\aaa\4\6.txt  
    41. # F:\aaa\4\7.txt  

内容概要:本文档详细介绍了Analog Devices公司生产的AD8436真均方根-直流(RMS-to-DC)转换器的技术细节及其应用场景。AD8436由三个独立模块构成:轨到轨FET输入放大器、高动态范围均方根计算内核和精密轨到轨输出放大器。该器件不仅体积小巧、功耗低,而且具有广泛的输入电压范围和快速响应特性。文档涵盖了AD8436的工作原理、配置选项、外部组件选择(如电容)、增益调节、单电源供电、电流互感器配置、接地故障检测、三相电源监测等方面的内容。此外,还特别强调了PCB设计注意事项和误差源分析,旨在帮助工程师更好地理解和应用这款高性能的RMS-DC转换器。 适合人群:从事模拟电路设计的专业工程师和技术人员,尤其是那些需要精确测量交流电信号均方根值的应用开发者。 使用场景及目标:①用于工业自动化、医疗设备、电力监控等领域,实现对交流电压或电流的精准测量;②适用于手持式数字万用表及其他便携式仪器仪表,提供高效的单电源解决方案;③在电流互感器配置中,用于检测微小的电流变化,保障电气安全;④应用于三相电力系统监控,优化建立时间和转换精度。 其他说明:为了确保最佳性能,文档推荐使用高质量的电容器件,并给出了详细的PCB布局指导。同时提醒用户关注电介质吸收和泄漏电流等因素对测量准确性的影响。
<think>好的,我现在需要帮助用户理解Pythonos.walk的含义和用法。用户之前问了关于os.walk的问题,现在需要详细回答,包括示例和相关问题。首先,我应该回顾自己之前的回答,确保信息一致,并且根据提供的引用资料来组织内容。首先,os.walk是用于遍历目录树的函数,生成目录中的子目录和文件。根据引用3,os.walk的参数包括top、topdown、onerror、followlinks。需要解释每个参数的作用,比如top是遍历的路径,topdown控制遍历顺序,默认先顶层后子目录。还要说明返回值是一个生成器,每次生成三元组(当前目录路径、子目录列表、文件列表)。接下来,用户需要用法示例。引用2中的示例可以展示基本用法,比如使用os.walk遍历指定目录并打印当前目录、子目录和文件。需要确保代码正确,用中文注释可能更友好。另外,引用1的示例也可以参考,展示如何用os.getcwd()作为遍历的起点,这可能对用户有帮助。另外,需要注意用户提到的LaTeX格式要求,但在这个回答中可能不需要数学公式,所以主要关注代码块和段落结构。必须使用$...$和$$...$$格式,但这里可能用不到独立公式,所以可能只需要正确使用代码块。然后,需要生成相关问题。考虑用户可能想了解os.walk的遍历顺序、如何处理错误、符号链接的影响,或者其他模块如os.listdir的区别。例如,如何递归删除目录?os.walkos.listdir有什么不同?如何处理遍历中的权限问题?还要确保回答结构清晰,分点解释含义、参数、返回值,再给出示例。可能需要分步骤说明,比如“1.函数定义”、“2.参数说明”等。引用资料需要自然地标注,比如在解释参数时提到引用3,示例部分提到引用2和引用1。需要检查LaTeX语法是否正确,但这里的内容可能不涉及数学表达式,所以可能只需要确保代码块正确使用反引号包裹,语言标记为python。例如,示例代码用三个反引号python开头,正确缩进。可能用户会有疑问,比如topdown设为False时的遍历顺序,或者如何处理遍历时出现的异常,比如引用3提到的onerror参数,可以举例说明如何定义一个错误处理函数。最后,生成的相关问题需要os.walk相关,可能包括性能优化、应用场景、常见错误处理等。例如,如何逆序遍历目录?如何过滤特定文件扩展名?如何利用os.walk统计文件数量?总结回答结构:先解释os.walk是什么,参数详细说明,返回值结构,然后给出示例代码,分步骤说明代码作用,最后提出相关问题。确保每个部分都有引用标注,如引用3解释参数,引用2和1提供示例。</think>### Python中`os.walk`的含义及用法详解 `os.walk`是Python标准库`os`模块中用于递归遍历目录结构的函数,可获取目录下所有子目录和文件的路径信息。它常用于文件管理、批量操作等场景。 --- #### 1. **函数定义参数说明** 函数签名: ```python os.walk(top, topdown=True, onerror=None, followlinks=False) ``` - **`top`**:需遍历的根目录路径(字符串类型)[^3]。 - **`topdown`**(可选):默认为`True`,表示先遍历顶层目录再遍历子目录;若为`False`,则从最深层的子目录开始遍历[^3]。 - **`onerror`**(可选):遍历过程中发生错误时调用的函数(如权限不足),需接收一个`OSError`实例作为参数[^3]。 - **`followlinks`**(可选):默认为`False`,若为`True`会遍历符号链接指向的目录[^3]。 --- #### 2. **返回值结构** `os.walk`返回一个生成器,每次迭代生成一个三元组: 1. **当前目录路径**(字符串)。 2. **子目录列表**(列表,仅包含目录名)。 3. **文件列表**(列表,仅包含文件名)。 例如: ```python ('/root', ['dir1', 'dir2'], ['file1.txt', 'file2.py']) ``` --- #### 3. **基础用法示例** 遍历目录并打印所有文件和子目录: ```python import os for root, dirs, files in os.walk('/path/to/directory'): print(f"当前目录:{root}") print(f"子目录:{dirs}") print(f"文件:{files}") print("-----") ``` - **`root`**:当前遍历的目录绝对路径。 - **`dirs`**:当前目录下的子目录列表(可通过修改此列表过滤目录)。 - **`files`**:当前目录下的文件列表[^2]。 --- #### 4. **实际应用场景** - **场景1:统计目录下所有文件数量** ```python file_count = 0 for root, dirs, files in os.walk('/path'): file_count += len(files) print(f"总文件数:{file_count}") ``` - **场景2:搜索特定扩展名的文件** ```python for root, dirs, files in os.walk('/path'): for file in files: if file.endswith('.txt'): print(os.path.join(root, file)) ``` --- #### 5. **注意事项** - **修改`dirs`列表实现过滤**:在遍历过程中修改`dirs`列表可跳过某些子目录(如排除隐藏目录): ```python for root, dirs, files in os.walk('/path'): dirs[:] = [d for d in dirs if not d.startswith('.')] # 忽略隐藏目录 ``` - **处理符号链接**:`followlinks=True`可能导致无限循环(如目录中存在指向父目录的符号链接)[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值