此篇文章会记录一下我以为比较实用的Git+Shell(由于笔者不用Sourcetree等图形化工具,命令行效率更高,同时通用价值也更高一点)的小技巧,或者也能够说是骚操做,一是为了给本身当备忘录,二是分享给有须要的同窗~git
日常咱们会这样获取全部已追踪的远程分支更新正则表达式
git remote update
git pull --all
复制代码
若是想获取所有远程分支并在本地建立(有时候拉取Github开源项目学习时,常常须要拉取所有分支),如下命令就能够帮你偷个懒。shell
for remote in `git branch -r `; do git branch --track $remote; done
复制代码
有没有一种痛苦,就是切换分支时,必定要写全写对名字才能切换,假如分支名又臭又长的话,那就...那就只有复制粘贴了!express
可是且慢!打开 .gitconfig 文件bash
open ~/.gitconfig
复制代码
在里面输入:工具
[alias]
find-branch = !sh -c \"git branch -a | grep -v remotes | grep $1 | head -n 1 | xargs git checkout\" 复制代码
保存后,此时能够直接在命令行里输入分支名的前几个字符就好了(只有你确保惟一,不然默认匹配找到的结果的第一个)post
如图,直接输入git find-branch ${shortcut}
这种形式,便可快速风骚切换。学习
(有心的同窗发现了,在.gitconfig和在.bash_profile里发挥想象力,增长各类alias别名,能够迅速提升工做效率)ui
有时候咱们须要对某些文件批量进行Git操做,而Git自己不必定知足这个需求的时候。能够参考如下命令:spa
git status -s | grep "README\.md" | sed 's/A //' | while read i; do git reset HEAD $i; done
git status -s | grep "README\.md" | sed 's/M //' | while read i; do git checkout --ours $i; done
复制代码
上述命令分为两步,一是将此项目中全部README.md
文件从暂存区恢复到工做区,二是将此项目中全部README.md
文件的冲突批量改成保留本身的改动。
上述命令通过必定的修改其实能够知足不少场景的!因此不要被限制住了。
如下摘自互联网,命令具体使用详情可自行检索~
xargs命令是给其余命令传递参数的一个过滤器,也是组合多个命令的一个工具。它擅长将标准输入数据转换成命令行参数,xargs可以处理管道或者stdin并将其转换成特定命令的命令参数。
sh命令是shell命令语言解释器,执行命令从标准输入读取或从一个文件中读取。
grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
sed 可依照脚本的指令来处理、编辑文本文件。用来自动编辑一个或多个文件、简化对文件的反复操做、编写转换程序
想了解更多也能够参考我以前写的这篇:Shells命令行学习笔记