答案:Python中递归读取目录所有文件内容可用os.walk()或pathlib.Path.rglob()方法,前者通过三元组遍历目录,后者语法更简洁;需注意文件编码、类型及大文件内存问题,建议按需选择文本或二进制模式读取。

Python 递归读取目录中所有文件内容
在 Python 中,可以使用 os.walk() 或 pathlib.Path.rglob() 来递归遍历目录并读取所有文件的内容。下面介绍两种常用方法,适用于不同场景。
os.walk() 是传统且高效的方式,能够递归进入子目录,返回目录路径、子目录名和文件名。
import os
<p>def read_all_files_with_os_walk(root_dir):
for dirpath, dirnames, filenames in os.walk(root_dir):
for filename in filenames:
file_path = os.path.join(dirpath, filename)
try:
with open(file_path, 'r', encoding='utf-8') as f:
content = f.read()
print(f"--- 内容来自: {file_path} ---")
print(content)
except Exception as e:
print(f"无法读取文件 {file_path}: {e}")</p>调用方式:
立即学习“Python免费学习笔记(深入)”;
里面有2个文件夹。其中这个文件名是:finishing,是我项目还没有请求后台的数据的模拟写法。请求后台数据之后,瀑布流的js有一点点变化,放在文件名是:finished。变化在于需要穿参数到后台,和填充的内容都用后台的数据填充。看自己项目需求来。由于chrome模拟器是不允许读取本地文件json的,所以如果你要进行测试,在hbuilder打开项目就可以看到效果啦,或者是火狐浏览器。
92
read_all_files_with_os_walk("/your/directory/path")
pathlib 是 Python 3.4+ 推荐的路径操作模块,rglob() 可直接匹配所有符合条件的文件,语法更直观。
from pathlib import Path
<p>def read_all_files_with_pathlib(root_dir):
root_path = Path(root_dir)</p><h1>匹配所有文件(可改为特定后缀如 "*.txt")</h1><pre class='brush:python;toolbar:false;'>for file_path in root_path.rglob("*"):
if file_path.is_file():
try:
content = file_path.read_text(encoding='utf-8')
print(f"--- 内容来自: {file_path} ---")
print(content)
except Exception as e:
print(f"无法读取文件 {file_path}: {e}")调用方式:
立即学习“Python免费学习笔记(深入)”;
read_all_files_with_pathlib("/your/directory/path")
read_text() 或 open(..., 'r') 会报错,必要时可用二进制模式判断或跳过。utf-8 覆盖大多数情况,但遇到 gbk 等中文编码文件时需调整。root_path.rglob("*.py") 只读取 Python 文件。for line in f)避免内存溢出。基本上就这些,根据需求选择合适的方法即可。
以上就是Python 递归读取目录中所有文件内容的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号