使用git远程修剪原点,我可以删除不在远程上的本地分支。

但是我还想删除从这些远程分支创建的本地分支(检查它们是否未合并会很好)。

我该怎么做呢?


当前回答

如果要删除所有已经合并到master中的本地分支,可以使用以下命令:

git branch --merged master | grep -v '^[ *]*master$' | xargs git branch -d

如果你使用main作为你的主分支,你应该相应地修改命令:

git branch --merged main | grep -v '^[ *]*main$' | xargs git branch -d

更多信息。

其他回答

以下是我的解决方案:

git fetch -p
git branch -vv | grep ": gone" | awk '{print $1}' | xargs git branch -d

-p用于删除远程上不再存在的任何远程跟踪引用。因此,第一步将删除对远程分支的引用。 -vv用于显示每个head的sha1和commit主题行,以及与上游分支的关系(如果有的话)。第二步将获取所有本地分支,grep命令将过滤掉已删除的分支。

尝试在git bash中,获取并修剪对已删除分支的引用,然后修剪跟踪已删除分支的本地分支:

git fetch -p && git branch -d `git branch -vv | grep ': gone]' | awk '{print $1}' | xargs`

记住先签出一个不会被删除的分支,这样就不会阻止该分支的删除。

正如@tzacks所说…有一个NPM包非常方便。只做:

npx git-removed-branches --prune

(我本想评论一下,但名声不够好)

您可以使用该命令:

git branch --merged master | grep -v "\* master" | xargs -n 1 git branch -d

Git清洁:删除已经合并的分支,包括分解命令

使用GUI?手动操作,但快捷方便。

$ git gui

选择“分支->删除”。您可以使用ctrl-click(窗口)选择多个分支并删除它们。