0

0

Python怎么删除文件夹_shutil.rmtree非空目录递归删除

P粉602998670

P粉602998670

发布时间:2026-03-17 10:55:35

|

228人浏览过

|

来源于php中文网

原创

shutil.rmtree 删除非空目录遇 PermissionError 时应传入 onerror 或 Python 3.12+ 的 onexc 回调函数,先用 os.chmod 改只读权限再重试;os.removedirs 仅删除全空目录链,而 rmtree 强制递归清空。

python怎么删除文件夹_shutil.rmtree非空目录递归删除

shutil.rmtree 删除非空目录时 PermissionError 怎么办

直接用 shutil.rmtree 删系统保护目录、正在被占用的文件夹,或者权限不足的路径(比如 Windows 上的只读文件),会抛 PermissionError: [WinError 5] 拒绝访问OSError: [Errno 13]。这不是函数写错了,是操作系统在拦你。

解决思路不是硬刚权限,而是让 rmtree 在出错时主动“低头”:把只读文件先改成可写,再删;遇到正在使用的文件,不强删,而是跳过或报错提示。

  • 传入 onerror 回调函数,捕获 PermissionError 后调用 os.chmod(path, stat.S_IWRITE) 改权限,再重试一次
  • Windows 下尤其注意:某些编辑器(如 VS Code、PyCharm)会锁住 .git/ 或 __pycache__/ 目录,删前最好关掉项目
  • 别对 /C:\os.environ['USERPROFILE'] 这类高危路径写死调用 rmtree,加一层路径合法性校验更稳妥

shutil.rmtree 和 os.removedirs 的核心区别在哪

os.removedirs 只能删「空目录链」——比如 a/b/c,必须 c 空、b 空、a 也空,它才一路删上去;只要中间某层有文件或子目录,就直接失败。而 shutil.rmtree 是真·递归清空,不管深浅、不管有没有内容,删完拉倒。

所以别指望 removedirs 替代 rmtree,它连一个含 .DS_Store 的空文件夹都删不掉(因为那不算“空”)。

立即学习Python免费学习笔记(深入)”;

HIX Translate
HIX Translate

由 ChatGPT 提供支持的智能AI翻译器

下载
  • 想安全删空目录结构(比如清理临时层级),用 os.removedirs
  • 要彻底清掉构建产物、缓存目录、测试输出,必须用 shutil.rmtree
  • rmtree 不返回值,删失败就抛异常;removedirs 成功返回 None,失败也抛异常,但错误类型不同(常是 OSError

Python 3.12+ 中 shutil.rmtree 的 onexc 参数替代 onerror

从 Python 3.12 开始,onerror 被标记为 deprecated,官方推荐用 onexc——参数名变了,签名也更明确:onexc(func, path, exc_info),其中 func 是触发异常的底层函数(比如 os.rmdir),path 是出问题的路径,exc_info 是异常三元组。

老代码里写的 onerror=lambda func, path, _ : ... 在 3.12+ 仍能跑,但会打 warning;新项目建议直接切 onexc,逻辑更清晰,也方便区分是 os.remove 失败还是 os.rmdir 失败。

  • 旧写法:shutil.rmtree(path, onerror=handle_error)
  • 新写法:shutil.rmtree(path, onexc=handle_exc),且 handle_exc 必须接收三个参数
  • 如果还要兼容 3.11 及更早版本,得做运行时判断:kwargs = {'onexc': h} if sys.version_info >= (3, 12) else {'onerror': h}

删除前要不要先检查目录是否存在或是否为目录

不需要额外调 os.path.existsos.path.isdir。因为 shutil.rmtree 本身就会检查:path 不存在 → 抛 FileNotFoundErrorpath 存在但不是目录 → 抛 NotADirectoryError(Python 3.9+)或更早的 OSError

与其写两行检查再删,不如直接 try-except 更干净。而且检查和删除之间存在竞态条件:比如你查完存在,下一秒就被别人删了,到 rmtree 执行时还是报错。

  • 想静默忽略“不存在”,就 catch FileNotFoundError
  • 想区分“不是目录”和“没权限”,就分别捕获 NotADirectoryErrorPermissionError
  • 不要用 os.path.isdir(path) and shutil.rmtree(path),多此一举还埋雷
实际删的时候,最麻烦的永远不是语法,是那个正在后台偷偷写日志的进程,或是 IDE 没释放的文件句柄。函数再稳,也得跟系统资源打交道。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

215

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

193

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

62

2026.01.05

自建git服务器
自建git服务器

git服务器是目前流行的分布式版本控制系统之一,可以让多人协同开发同一个项目。本专题为大家提供自建git服务器相关的各种文章、以及下载和课程。

999

2023.07.05

git和svn的区别
git和svn的区别

git和svn的区别:1、定义不同;2、模型类型不同;3、存储单元不同;4、是否拥有全局版本号;5、内容完整性不同;6、版本库不同;7、克隆目录速度不同;8、分支不同。php中文网为大家带来了git和svn的相关知识、以及相关文章等内容。

582

2023.07.06

git撤销提交的commit
git撤销提交的commit

Git是一个强大的版本控制系统,它提供了很多功能帮助开发人员有效地管理和控制代码的变更,本专题为大家提供git 撤销提交的commit相关的各种文章内容,供大家免费下载体验。

275

2023.07.24

git提交错误怎么撤回
git提交错误怎么撤回

git提交错误撤回的方法:git reset head^:撤回最后一次提交,恢复到提交前状态。git revert head:创建新提交,内容与之前提交相反。git reset :使用提交的 sha-1 哈希撤回指定提交。交互式舞台区:标记要撤回的特定更改,然后提交,排除已撤回更改。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

571

2024.04.09

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号