使用git远程修剪原点,我可以删除不在远程上的本地分支。
但是我还想删除从这些远程分支创建的本地分支(检查它们是否未合并会很好)。
我该怎么做呢?
使用git远程修剪原点,我可以删除不在远程上的本地分支。
但是我还想删除从这些远程分支创建的本地分支(检查它们是否未合并会很好)。
我该怎么做呢?
当前回答
Windows的解决方案
适用于Microsoft Windows Powershell:
Git结帐大师;Git远程更新源——prune;git branch -vv | Select-String -Pattern ": gone]" | % {$_.toString(). trim()。Split(" ")[0]} | % {git branch -d $_}
解释
Git签出主切换到主分支
Git远程更新来源——修剪远程分支
Git分支-vv获取所有分支的详细输出(Git引用)
Select-String -Pattern ": gone]"只获取已从远程删除的记录。
% {$_.toString()。Split(" ")[0]}获取分支名称
% {git branch -d $_}删除分支
其他回答
删除所有没有更新到master的分支
git co master && git branch | sed s/\*/\ / | xargs git branch -d 2> /dev/null
正如@tzacks所说…有一个NPM包非常方便。只做:
npx git-removed-branches --prune
(我本想评论一下,但名声不够好)
修剪完成后,你可以使用git branch -r获取远程分支的列表。带有远程跟踪分支的分支列表可以使用git branch -vv检索。因此,使用这两个列表,您可以找到不在远程列表中的远程跟踪分支。
这一行应该做的把戏(需要bash或zsh,不会与标准的Bourne shell工作):
git fetch -p ; git branch -r | awk '{print $1}' | egrep -v -f /dev/fd/0 <(git branch -vv | grep origin) | awk '{print $1}' | xargs git branch -d
该字符串获取远程分支的列表,并通过标准输入将其传递给egrep。并过滤具有远程跟踪分支的分支(使用git branch -vv并过滤那些具有origin的分支),然后获得输出的第一列,这将是分支名称。最后将所有分支名称传递给delete branch命令。
由于它使用的是-d选项,所以在运行此命令时,它不会删除尚未合并到您所在分支中的分支。
你可以通过一些简单的操作来做到这一点:
输出你所有的分支到一个临时文件:
git branch > branches.tmp
打开文件并删除分支以排除它们从本地删除(分支如develop/master/main/…) 通过cat命令将分支名称传递给xargs并删除分支:
cat branches.tmp | xargs git branch -D
虽然迟到了,但是你可以使用——no-contains选项来避免在使用branch -merged时删除你的主分支
git branch --no-contains master --merged master | xargs git branch -d