分享几个组合Git+Shell提升工作效率的小技巧
前言
此篇文章会记录一下我觉得比较实用的Git+Shell(因为笔者不用Sourcetree等图形化工具,命令行效率更高,同时通用价值也更高一点)的小技巧,或者也可以说是骚操作,一是为了给自己当备忘录,二是分享给有需要的同学~
技巧
批量拉取全部远程分支
平常我们会这样获取所有已追踪的远程分支更新
git remote update
git pull --all
复制代码
如果想获取全部远程分支并在本地创建(有时候拉取Github开源项目学习时,经常需要拉取全部分支),以下命令就可以帮你偷个懒。
for remote in `git branch -r `; do git branch --track $remote; done
复制代码
快速切换分支
有没有一种痛苦,就是切换分支时,一定要写全写对名字才能切换,假如分支名又臭又长的话,那就...那就只有复制粘贴了!
但是且慢!打开 .gitconfig 文件
open ~/.gitconfig
复制代码
在里面输入:
[alias]
find-branch = !sh -c "git branch -a | grep -v remotes | grep $1 | head -n 1 | xargs git checkout"
复制代码
保存后,此时可以直接在命令行里输入分支名的前几个字符就行了(只有你确保唯一,否则默认匹配找到的结果的第一个)
如图,直接输入git find-branch $这种形式,即可快速风骚切换。
(有心的同学发现了,在.gitconfig和在.bash_profile里发挥想象力,增加各种alias别名,可以迅速提高工作效率)
批量对部分文件执行Git命令
有时候我们需要对某些文件批量进行Git操作,而Git本身不一定满足这个需求的时候。可以参考以下命令:
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命令是给其他命令传递参数的一个过滤器,也是组合多个命令的一个工具。它擅长将标准输入数据转换成命令行参数,xargs能够处理管道或者stdin并将其转换成特定命令的命令参数。
sh
sh命令是shell命令语言解释器,执行命令从标准输入读取或从一个文件中读取。
grep
grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
sed
sed 可依照脚本的指令来处理、编辑文本文件。用来自动编辑一个或多个文件、简化对文件的反复操作、编写转换程序
领取专属 10元无门槛券
私享最新 技术干货