git批量删除本地多余分支

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


1. 强制删除所有分支(仅保留指定分支)

若需保留 main 分支,同时强制删除其他所有分支(包括未合并的分支):

bash 复制代码
git branch | grep -v "main" | xargs git branch -D

说明

  • git branch:列出所有本地分支。
  • grep -v "main":过滤掉包含 main 的行(-v 表示反向匹配)。
  • xargs git branch -D:将分支名传递给 git branch -D 强制删除(-D 跳过未合并检查)。

扩展 :保留多个分支(如 maindevtestprod):

bash 复制代码
git branch | grep -vE "main|dev|test|prod" | xargs git branch -D
  • grep -vE:使用扩展正则表达式(-E)匹配多个关键词。

2. 安全删除已合并的分支(推荐)

为避免误删未合并的分支,可先筛选出已合并到 main 的分支,再批量删除:

css 复制代码
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

css 复制代码
bash
git branch | grep -vE "main|dev|test" | xargs -p git branch -D
  • -p:每次执行前提示确认(输入 y 确认删除)。

注意事项

  1. 远程分支:上述命令仅操作本地分支。若需清理远程分支,需使用:

    bash 复制代码
    git push origin --delete 分支名
  2. 未合并分支 :强制删除(-D)会丢失未合并的代码,建议先确认分支状态:

    bash 复制代码
    git branch --no-merged  # 查看未合并的分支
  3. 分支名含空格 :若分支名包含空格,需改用 git for-each-ref 替代 git branch

    bash 复制代码
    git for-each-ref --format='%(refname:short)' refs/heads/ | grep -vE "main|dev|test|prod" | xargs git branch -D

相关推荐
飘尘6 分钟前
前端转型全栈(Java后端)的快速上手指引
前端·后端·全栈
一颗烂土豆15 分钟前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
浏览器工程师1 小时前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
行者全栈架构师1 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
雨季mo浅忆1 小时前
VSCode自动格式化三要素
前端
Chenyiax1 小时前
从一次请求看懂 OkHttp:架构、调度与连接管理
后端
爱勇宝2 小时前
深扒 Anthropic 1680 位工程师简历:应届生几乎没机会,AI 公司最缺的不是博士
前端·后端·程序员
AskHarries2 小时前
工具失败时怎么办:重试、回滚、人工确认和风险提示
后端·程序员
kyriewen3 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
苏三说技术4 小时前
Claude Code从失控到起飞,只用了这些技巧
后端