git删除本地分支和远程分支

今天准备找以前的一个分支,发现自己本地的分支已经很多了,决定清除一下,然后这里记录一下批量删除分支的命令,免得后面又忘。

说批量之前先说单个的。

删除本地的单个分支

git branch -d [分支名]

删除远程的单个分支

git push origin :[分支名]

或者

git push origin -d [分支名]

批量删除本地分支

git branch -a | grep 'lyn_' | xargs git branch -D

解释一下:git branch -a(--all)表示列出本地所有分支,grep ‘lyn_’表示正则匹配本地所有分支中分支名有'lyn_'扥分支,然后将以上匹配结果作为参数传给git branch -D,执行删除本地分支命令,‘|’相当于一个管道符,将上一段的结果传给下一段

有时候分支命名上没什么规则,只想保留某几个正在开发中的分支,删除所有其他的分支,就可以用下面命令:

git branch -a | grep -v -E 'A|B' | xargs git branch -D

上述命令表示删除除了A和B分支外的所有本地分支

批量删除远程分支

git branch -r| grep 'lyn_' | sed 's/origin///g' | xargs -I {} git push origin :{}

git branch -r表示列出所有远程分支,匹配含有lyn_的分支,sed 's/origin///g'能够把接受到的分支都过滤掉开头的origin/得到实际的分支名 (大概这个意思),比如origin/A分支执行了 sed 's/origin///g'命令就能得到A  ,然后将A这个分支作为参数传给下一个命令,-I {} 使用占位符 来构造 后面的命令,也就是接收到了上个命令的执行结果A执行git push origin :A

 顺便补充一下本地分支与远程分支的关联与取消:

1.取消本地目录下关联的远程库

git remote remove origin

2.将本地目录与远程关联

git remote add origin git@github.com:git_username/repository_name.git

如果将本地目录与远程关联后,远程目录包含本地目录没有的内容的时候,git pull会出现如下报错:

fatal: refusing to merge unrelated histories

可以用以下命令来忽略(要解决冲突)

git pull origin master --allow-unrelated-histories
原文地址:https://www.cnblogs.com/luoyanan/p/10875601.html