我有一个名为Test_Branch的分支。当我尝试使用推荐方法删除它时,我得到以下错误:

无法删除在'[目录签出的分支'Test_Branch' 位置]。

除此之外,我没有得到其他信息。我可以轻易地吹走远程分支,但本地分支不会消失。


当前回答

切换到其他分支并删除Test_Branch,如下所示:

$ git checkout master
$ git branch -d Test_Branch

如果上面的命令给你错误-分支“Test_Branch”没有完全合并。如果你确定你想要删除它,并且仍然想要删除它,那么你可以使用-D来强制删除它,而不是-D,如下所示:

$ git branch -D Test_Branch

要从远程删除Test_Branch,执行:

git push origin --delete Test_Branch

其他回答

也遇到了同样的问题, 签出到不同的分支,使用git branch -D branch_name 为我工作

今天git branch -a报告的分支遇到了这个问题,看起来像这样:remotes/coolsnake/dev,即在注册的git remote add中对“远程”分支的本地引用…遥控器。

当你尝试

git branch -d remotes/coolsnake/dev

你会得到这样的错误:branch 'remotes/coolsnake/dev' not found。

神奇的是要记住,这些是引用,必须删除通过

git update-ref -d remotes/coolsnake/dev

(as https://superuser.com/questions/283309/

我花了一段时间才发现我的错误,只有TortoiseGit可以做到这一点,当我陷入困境时,我才走上了正确的道路。谷歌没有提供任何有用的东西,尽管有几种不同的方法。(不,我已经找到了我需要的东西,还有git:如何删除一个本地引用分支?,这并没有显示,因为我已经忘记了这些分支是引用的“ref”位。)

希望这能帮助其他人摆脱困境,当他们和我在同一条船上时,试图过滤/选择性地删除repo中的一些分支,其中一些由于之前的git远程添加命令而存在。


在shell脚本中,这可能是这样的:

#! /bin/bash
#
# Remove GNU/cesanta branches so we cannot accidentally merge or cherrypick from them!
# 

# commit hash is first GNU commit
R=218428662e6f8d30a83cf8a89f531553f1156d25

for f in $( git tag -l ; git branch -a ) ; do 
    echo "$f"
    X=$(git merge-base $R "$f" ) 
    #echo "X=[$X]" 
    if test "$X" = "$R" ; then 
        echo GNU 
        git branch -D "$f" 
        git update-ref -d "refs/$f" 
        git tag -d "$f" 
        #git push origin --delete "$f" 
    else 
        echo CIVETWEB 
    fi
done

您可能已经签出了Test_Branch,当它是您当前的分支时,您可能无法删除它。签出一个不同的分支,然后尝试删除Test_Branch。

大多数初级程序员面临的问题

无法删除分支“my-branch-name”

因为它们已经在那根树枝上了。

删除您正在处理的分支是不符合逻辑的。

只需切换到另一个分支,比如master或dev,然后删除你想要的分支:

Git检查开发

Git branch -d my-branch-name

无需强制删除,您可以删除该分支

今天遇到了这个问题,换到另一个分支也没有帮助。结果是我的工作树信息被损坏了,有一个工作树与我的工作目录具有相同的文件夹路径,头部指向分支(git工作树列表)。我删除了引用它的.git/worktree/文件夹,git分支-d工作了。