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

相关推荐
majingming1232 小时前
FUNCTION
java·前端·javascript
zopple2 小时前
常见的 Spring 项目目录结构
java·后端·spring
A_nanda3 小时前
Vue项目升级
前端·vue3·vue2
SuperEugene3 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
abigale034 小时前
【浏览器 API / 网络请求 / 文件处理】前端文件上传全流程:从基础上传到断点续传
前端·typescript·文件上传·vue cli
Setsuna_F_Seiei4 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
cjy0001114 小时前
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
java·spring boot·后端
新缸中之脑4 小时前
追踪来自Agent的Web 流量
前端
wefly20175 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
小江的记录本5 小时前
【事务】Spring Framework核心——事务管理:ACID特性、隔离级别、传播行为、@Transactional底层原理、失效场景
java·数据库·分布式·后端·sql·spring·面试