新闻中心

Python 递归读取目录中所有文件内容

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

python 递归读取目录中所有文件内容

Python 递归读取目录中所有文件内容

在 Python 中,可以使用 os.walk()pathlib.Path.rglob() 来递归遍历目录并读取所有文件的内容。下面介绍两种常用方法,适用于不同场景。

1. 使用 os.walk() 遍历并读取文件内容

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>

调用方式:

SeoShop SeoShop

SeoShop网店系统全站纯静态html生成更符合搜索引擎优化,并修改了以前许多js代码,取消了连接地址的js代码更换为纯div+css格式,并且所有文件可自定义url和文件名,自定义内部连接,自定义外部连接,等多个符合SEO搜索引擎优化的设置,让您的网店更容易让搜索引擎收录. 简单易用 极速网店真正做到以人为本、以用户体验为中心,能使您快速搭建网上购物网站。后台管理操作简单,一目了然,没有夹杂多

SeoShop 0 查看详情 SeoShop
read_all_files_with_os_walk("/your/directory/path")

2. 使用 pathlib.Path.rglob() 更简洁的写法

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}")

调用方式:

read_all_files_with_pathlib("/your/directory/path")

3. 注意事项与建议

  • 某些文件可能不是文本文件(如图片、二进制文件),使用 read_text()open(..., 'r') 会报错,必要时可用二进制模式判断或跳过。
  • 指定编码很重要,utf-8 覆盖大多数情况,但遇到 gbk 等中文编码文件时需调整。
  • 若只想读取特定类型文件,可修改匹配模式,例如:root_path.rglob("*.py") 只读取 Python 文件。
  • 大文件建议逐行读取(如使用 for line in f)避免内存溢出。

基本上就这些,根据需求选择合适的方法即可。

以上就是Python 递归读取目录中所有文件内容的详细内容,更多请关注其它相关文章!


# 编码  # 巫溪网站推广建设  # 巴中网站建设推广多少钱  # 淮安标准网站建设流程  # seo设计中心  # 岳麓区抖音营销推广方法  # 企业网站优化话术  # 宜昌seo搜索推广  # 多个  # 搜索引擎优化  # 大文件  # 您的  # 如何做  # 目录中  # 网店  # 自定义  # 遍历  # 递归  # python  # 台湾推广营销软文  # 推广网站合作  # 公司网站全网推广运营模式 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: J*a 递归快速排序中静态变量的状态管理与陷阱  Pygame教程:解决用户输入与游戏状态更新不同步问题  qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决  顺丰快递查单号物流信息 顺丰快递小程序查询入口  Promise错误处理:在catch后终止链式then执行的策略  Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】  Golang如何使用new_Go new分配内存机制讲解  如何使用Go和Martini动态服务解码后的图片  支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样  处理Kafka消费者会话超时:深入理解消息处理语义与幂等性  mysql如何设置表访问权限_mysql表访问权限配置  妖精动漫免费平台 妖精动漫官网资源观看网址  12306选座怎么选到特殊座位_12306特殊座位选择注意事项  处理嵌套交互式控件:前端可访问性指南  拼多多赚钱渠道_拼多多收益来源  厨房不锈钢水槽发黑生锈怎么处理_水槽用可乐+锡纸2分钟抛亮如新  Win11怎么开启卓越性能模式 Win11电源选项启用高性能释放硬件潜力【方法】  qq游戏跨平台入口_qq游戏多设备同步登录  微信语音通话掉线如何解决 微信语音通话稳定优化方法  企业名称高精度匹配:N-gram方法在结构相似性分析中的应用  在VS Code中配置和运行Dart程序的完整步骤  sublime如何只显示或隐藏特定类型文件_sublime侧边栏文件过滤  使用CSS更改登录屏幕输入框中PNG图标颜色的策略与局限性  神经网络二分类模型训练异常:高损失与完美验证准确率的排查与修正  Go语言中动态执行代码字符串的策略与实践  UC浏览器官网入口2025最新 UC浏览器网页版正式地址  圆通快递查询实时追踪 圆通物流包裹状态快速查看  AI抖音网页版免费视频入口 AI抖音网页端最新视频实时观看  在Pyomo中实现基于变量的条件约束:Big-M方法详解  QQ邮箱官方网站登录入口_QQ邮箱网页版在线使用  HTML长属性值处理:表单action路径优化与代码规范应对  QQ邮箱电脑版登录入口_QQ邮箱官方网站登录平台  excel如何生成目录 excel一键生成工作表目录超链接  yandex入口引擎手机版 yandex安卓版下载入口  PHP中高效并行检查多链接状态的教程  Go语言中的*string:深入理解字符串指针  美团外卖商家服务中心入口 美团商家版官网入口  京东单号查询入口_京东快递订单追踪入口  LINUX怎么设置定时任务_LINUX crontab配置教程  如何优雅地扩展SprykerGlue后端API授权逻辑,使用spryker/glue-backend-api-application-authorization-connector-extension  html怎么在cmd下运行php文件_cmd运行html中php文件方法【教程】  支付宝如何管理隐私设置_支付宝隐私保护的配置技巧  智慧团建扫码登录入口 智慧团建扫码登录入口官网版​  菜鸟取件码是什么怎么查 最全查询渠道汇总  J*aScript动态修改指定div内所有a标签样式指南  《刺客信条:影》PS5 Pro和Switch 2画面对比  Golang如何实现Web文件静态资源服务器_Golang静态资源服务器开发与实践  CSS图片焦点样式实现教程:理解与应用tabindex属性  天眼查企业查询官网入口 天眼查官方网页版查询  qq游戏网页版直接玩_qq游戏免下载快速入口 

搜索