钱匾 发表于 2026-3-4 16:05:03

git批量删除本地多余分支

在长期开发中,本地仓库容易积累大量忘记删除的旧分支。手动逐个删除(git branch -D 分支名)效率低下,可通过管道命令批量处理。
1. 强制删除所有分支(仅保留指定分支)

若需保留 main 分支,同时强制删除其他所有分支(包括未合并的分支):
git branch | grep -v "main" | xargs git branch -D说明:

[*]git branch:列出所有本地分支。
[*]grep -v "main":过滤掉包含 main 的行(-v 表示反向匹配)。
[*]xargs git branch -D:将分支名传递给 git branch -D 强制删除(-D 跳过未合并检查)。
扩展:保留多个分支(如 main、dev、test、prod):
git branch | grep -vE "main|dev|test|prod" | xargs git branch -D

[*]grep -vE:使用扩展正则表达式(-E)匹配多个关键词。
2. 安全删除已合并的分支(推荐)

为避免误删未合并的分支,可先筛选出已合并到 main 的分支,再批量删除:
bash
git branch --merged main | grep -vE "main|dev|test|prod" | xargs git branch -d说明:

[*]git branch --merged main:仅列出已合并到 main 的分支。
[*]git branch -d:安全删除(若分支未合并会报错,需改用 -D 强制删除)。
[*]适用场景:定期清理已完成合并的功能分支。
3. 交互式确认删除(更谨慎)

若需逐个确认分支是否删除,可结合 xargs -p:
bash
git branch | grep -vE "main|dev|test" | xargs -p git branch -D

[*]-p:每次执行前提示确认(输入 y 确认删除)。
注意事项


[*]远程分支:上述命令仅操作本地分支。若需清理远程分支,需使用:
git push origin --delete 分支名
[*]未合并分支:强制删除(-D)会丢失未合并的代码,建议先确认分支状态:
git branch --no-merged# 查看未合并的分支
[*]分支名含空格:若分支名包含空格,需改用 git for-each-ref 替代 git branch:
git for-each-ref --format='%(refname:short)' refs/heads/ | grep -vE "main|dev|test|prod" | xargs git branch -D

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

丧血槌 发表于 2026-3-7 19:41:19

感谢分享,学习下。

翁真如 发表于 2026-3-9 04:31:09

过来提前占个楼

套缈 发表于 4 天前

yyds。多谢分享

肿圬后 发表于 前天 21:15

很好很强大我过来先占个楼 待编辑
页: [1]
查看完整版本: git批量删除本地多余分支