今天准备找以前的一个分支,发现自己本地的分支已经很多了,决定清除一下,然后这里记录一下批量删除分支的命令,免得后面又忘。
说批量之前先说单个的。
删除本地的单个分支:
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
来源:oschina
链接:https://my.oschina.net/u/4358285/blog/3535429