我的存储库中有一个master分支和一个dev分支。我想从我的计算机中删除主分支,这样我就不会意外地提交它(它已经发生了..)。
这里有关于如何在本地和远程删除分支的问题,但我还没有找到如何只在本地删除一个分支。
一个回答是这样说的:
git branch -d local_branch_name
但我尝试了一下,分支仍然显示在GitHub应用程序中。
我的存储库中有一个master分支和一个dev分支。我想从我的计算机中删除主分支,这样我就不会意外地提交它(它已经发生了..)。
这里有关于如何在本地和远程删除分支的问题,但我还没有找到如何只在本地删除一个分支。
一个回答是这样说的:
git branch -d local_branch_name
但我尝试了一下,分支仍然显示在GitHub应用程序中。
当前回答
你可以使用Git GUI在windows上删除多个分支:
转到项目文件夹 打开Git Gui: 点击“分支”: 现在选择“删除”: 如果你想删除所有的分支,不管它们是否合并,然后勾选“总是(不执行合并检查)”。
其他回答
我认为(基于您的评论),我理解您想要做的事情:您希望存储库的本地副本既没有普通的本地分支主,也没有远程跟踪分支源/主,即使您克隆的存储库—github—有一个您不希望从github版本中删除的本地分支主。
你可以通过在本地删除远程跟踪分支来做到这一点,但它只会在每次你要求git将本地存储库与远程存储库同步时返回,因为你的git会问他们的git“你有什么分支”,它会说“我有master”,所以你的git(重新)为你创建了origin/master,这样你的存储库就有了他们的存储库。
使用命令行接口在本地删除远程跟踪分支:
git branch -d -r origin/master
但是,它会在重新同步时返回。也有可能解决这个问题(使用remote.origin.fetch操作),但是最好不要在本地创建或修改master。
您需要切换到另一个分支并尝试同样的方法。
Git分支-d
git branch | grep -v "develop" | grep -v "master" | xargs git branch -D
简单易行。它会删除所有的除了你正在工作和“开发”和“掌握”。
就我对原始问题的理解, 您错误地将提交添加到本地主服务器 并没有推动这些变化。 现在您想要取消更改,并希望删除本地更改,并从远程分支创建一个新的主分支。
您可以重置您的更改,并从远程服务器重新加载master:
git reset --hard origin/master
你可以使用Git GUI在windows上删除多个分支:
转到项目文件夹 打开Git Gui: 点击“分支”: 现在选择“删除”: 如果你想删除所有的分支,不管它们是否合并,然后勾选“总是(不执行合并检查)”。