本篇内容介绍了“怎么用git实现快速定位提交”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
谁动了我的代码?
谁的 bug 指到了我的头上?
团队合作时,经常会出现这样的问题。这时候可以使用 git blame <file>
来定位代码的最后一次修改。但是,有一个问题,这并不能看出本行代码以前的修改。比如项目组中某人对全部代码进行了格式化,git blame
就失去了作用。此时,可以与另一个有用的命令 git log -p <file>
结合使用,可以查看文件的更改历史与明细,最终找到这个锅究竟应该由谁来背。
git blame -L 10,12 package.json
git log -p -L 10,12:package.json
当你经常工作于 A 与 B 两个分支,需要来回切。这时命令应该是 git checkout A
,但这里有一个更简单的命令,git checkout -
,表示切到最近的一次分支。如果你需要把 B 分支的内容合并过来,可以使用 git merge -
。
题外话,cd -
代表进入最近目录,也相当实用。
git checkout -
git merge -
统计项目各个成员 commit 的情况,比如你可以查看你自己的项目的 commit 数以及他人对你项目的贡献数
git shortlog -sn
git shortlog -sn --no-merges # 不包含 merge commit
如果你的 commit message 比较规范,比如会关联 issuse 或者当前任务或者 bug 的编号,此时根据 commit message 快速定位:git log --grep "Add"
。
如果你的 commit message 不太规范,只记得改了哪几行代码,此时也可以根据每次提交的信息查找关键字,是 git log -S "setTimeout"
。
同时,也可以根据作者,时间来辅助快速定位。
git log --since="0 am" # 查看今日的提交
git log --author="shfshanyue" # 查看 shfshanyue 的提交
git log --grep="#12" # 查找提交信息中包含关键字的提交
git log -S "setTimeout" # 查看提交内容中包含关键字的提交
如何查找包换关键字的全部文件?
使用 VS Code
可以全局搜索,使用 grep
也可以通过 grep -rn <keyword>
来全局搜索。
不过,它们也会连带搜索忽略文件,比如前端著名的两个文件夹 node_modules
和 public(dist/build)
。虽然 grep 可以指定 --exclude
来忽略文件,不过 git
来的更方便一些。
这时,可以使用 git grep <keyword>
来解决这个问题,另外 ag 也可以解决这个问题。
grep -rn <keyword>
grep -rn <keyword> --exclude config.js --exclude-dir node_modules
git grep <keyword>
ag <keyword>
“怎么用git实现快速定位提交”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。