删除 Git 中的所有本地分支
旧的本地分支使你的本地仓库变得混乱,但没有提供进一步的价值。你可以在本教程的帮助下一次性删除所有本地分支。
我们使用诸如 grep
、xargs
和 for-each-ref
之类的命令来为此任务编写脚本。我们为不同的用例展示了各种选项。
我们还提供了一个在教程结束时删除所有本地分支的单行快速 hack。
删除 Git 中所有本地分支的详细脚本,除了 master
我们将以下脚本编写到 Git 删除除 master
分支之外的所有本地分支。
git for-each-ref --format '%(refname:short)' refs/heads | grep -v "master\|main\|develop" |
xargs git branch -D
此脚本将删除除 master
分支之外的所有本地分支,包括未合并的分支。
让我们分解这个脚本,看看它是如何工作的。
-
for-each-ref
遍历 repo 中的所有引用。format
字符串'%refname:short'
从可迭代对象中提取一个简短的 ref 名称,并且refs/heads
指向它们的heads
。我们使用管道
|
将for-each-ref
的输出传递给grep
命令运算符。 -
grep
命令搜索传递给它的参考头以匹配表达式字符串master\|main\|develop
。这涵盖了你的master
分支的不同名称 - 你可能已将它们命名为main
或develop
。 -
grep
命令中的-v
选项用于反向选择。因此,它只会选择那些不匹配表达式master\|main\|develop
的分支 - 本质上,它会选择除master
之外的所有本地分支。 -
最后,
xargs
命令获取所有这些选定的分支并将它们作为参数传递给命令git branch -D
。git branch -D
是强制删除所有作为参数传递的分支的命令。
使用 Git 中的 -d
选项修改脚本以仅删除合并的分支
我们可以修改上面的脚本只删除合并的分支。我们用 -d
选项替换最后的 -D
选项。
-d
是一个软删除选项,仅删除合并的分支。
git for-each-ref --format '%(refname:short)' refs/heads | grep -v "master\|main\|develop" |
xargs git branch -d
我们看到 first_branch
已合并,但 second_branch
未合并。
我们修改后的脚本只删除了合并的 first_branch
,但留下了未合并的 second_branch
。
使用更简单的脚本删除 Git 中的所有本地分支
有些人可能会觉得上面的脚本过于复杂和过分。我们可以使用更简单的脚本来完成相同的任务。
git branch | grep -v "master\|main\|develop" | xargs git branch -D
该脚本用简单的 git branch
命令替换了复杂的 for-each-ref
。
请注意,Git 不建议在脚本中使用 git branch
。但有时我们可以偏离最佳实践以获得快速解决方案。
修改脚本以删除名称类似于 master
的本地分支,例如 Git 中的 master-prod
有时,你的仓库可能有名称类似于 master
的分支。例如,你的某些分支可能具有诸如 master-prod
或 master-draft
之类的名称。
我们可以将脚本中的正则表达式从 "master\|main\|develop"
修改为 "master$\|main$\|develop$"
来实现此功能。
git branch | grep -v "master$\|main$\|develop$" | xargs git branch -D
删除 Git 中所有本地分支的简短脚本
我们可以将巧妙的正则表达式传递给 grep
以进一步缩短我们的脚本。
git checkout master
git branch | grep -v "^*" |xargs git branch -D
表达式"^*"
表示从当前分支 (*
) 开始 (^
) 的所有分支。我们首先做了 git checkout master
,所以我们当前的分支是 master
。
因此 -v "^*"
过滤掉我们当前的分支 master
并删除所有其他本地分支。
Git 中删除所有本地分支的单行硬删除命令
最后,如承诺的那样,我们将向你展示一个单行硬删除命令,用于删除 Git 中的所有本地分支。
git branch -D $(git branch)
此命令删除除你所在的分支之外的所有分支。
相关文章
如何在 Windows 系统中卸载 git
发布时间:2023/04/09 浏览次数:223 分类:Git
-
在这篇简短的文章中,我们将学习如何卸载 Git,以及如何在从个人计算机的目录中卸载 Git 后删除这些文件。
Git 如何重命名本地分支
发布时间:2023/04/09 浏览次数:64 分类:Git
-
大多数情况下,重命名分支机构是由于上述情况。 因此,在本教程中,我们将学习使用下面提到的技术更改本地 Git 分支的名称。
重命名 Git 存储库中的文件和目录
发布时间:2023/04/09 浏览次数:102 分类:Git
-
在本文中,我们将讨论 git 中的重命名过程。 我们使用 Git Rename 来更改工作目录中文件和文件夹的名称。
在 Git 中取消初始化存储库
发布时间:2023/04/09 浏览次数:187 分类:Git
-
本本文介绍如何通过 Git 命令行取消初始化 Git 存储库。git init 命令开发一个新的空置 Git 存储库。 它还用于重新初始化已经存在的 Git 存储库。
Git 仓库名称该如何命名
发布时间:2023/04/09 浏览次数:208 分类:Git
-
使用 Git 时,选择一个简洁且最新的存储库名称是一项艰巨的任务。本教程介绍了如何以独特的方式命名 Git 存储库。
配置 Git 以忽略文件模式更改
发布时间:2023/04/09 浏览次数:67 分类:Git
-
本文讨论配置 Git 以忽略文件更改 chmod 所需的步骤。 如果您更改 Git 正在跟踪的文件的权限,系统将在该文件中注册更改。
在 Git 中暂存已删除的文件
发布时间:2023/04/09 浏览次数:93 分类:Git
-
本文讨论了在 Git 中暂存已删除文件的必要步骤。我们知道 rm 命令可以删除一个文件,而无需将其从工作目录中移除。 那么,我们如何暂存已删除的文件以进行提交呢?
在 Git 中显示冲突文件
发布时间:2023/04/09 浏览次数:139 分类:Git
-
本文讨论在 Git 中列出冲突文件的最简单和最干净的方法。 我们可以使用 git status 命令,但这很麻烦,尤其是当我们有大量不冲突的文件时。