zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    directives vant之Field输入限制【v-input-float】
    【vue】 typeScript OSS图片压缩处理工具类
    vue单页面加载js方法
    H5网页打开App以及App内某个页面
    适配iphoneX万能方法!!!
    固定底部button按钮,兼容各种手机、微信等【flex布局】
    天行数据小程序demo
    iview Weapp index索引器 cityjs 增加每个城市的code值
    小程序上传图片至七牛云(支持多张上传、预览、删除图片)
    (转)异步与非阻塞之间的区别(看到的最清晰的说明)
  • 原文地址:https://www.cnblogs.com/luoyanan/p/10875601.html
Copyright © 2011-2022 走看看