参考:
2.3 Git 基础 - 检察提交汗青
git log 参数说明:
- –author 指定作者
- –stat 显示每次更新的文件修改统计信息,会列出具体文件列表
- –shortstat 统计每个commit 的文件修改行数,包括增加,删除,但不列出文件列表:
- –numstat 统计每个commit 的文件修改行数,包括增加,删除,并列出文件列表:
- –p 选项展开显示每次提交的内容差异,用 -2 则仅显示最近的两次更新
- 例如:git log -p -2
- –name-only 仅在提交信息后显示已修改的文件清单
- –name-status 显示新增、修改、删除的文件清单
- –abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符
- –relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)
- –graph 显示 ASCII 图形表示的分支合并历史
- –pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)
- 例如: git log –pretty=oneline ; git log –pretty=short ; git log –pretty=full ; git log –pretty=fuller
- –pretty=tformat: 可以定制要显示的记录格式,这样的输出便于后期编程提取分析
- 例如:git log –pretty=format:”“%h - %an, %ar : %s””
- 下面列出了常用的格式占位符写法及其代表的意义。
- 选项 说明
- %H 提交对象(commit)的完整哈希字串
- %h 提交对象的简短哈希字串
- %T 树对象(tree)的完整哈希字串
- %t 树对象的简短哈希字串
- %P 父对象(parent)的完整哈希字串
- %p 父对象的简短哈希字串
- %an 作者(author)的名字
- %ae 作者的电子邮件地址
- %ad 作者修订日期(可以用 -date= 选项定制格式)
- %ar 作者修订日期,按多久以前的方式显示
- %cn 提交者(committer)的名字
- %ce 提交者的电子邮件地址
- %cd 提交日期
- %cr 提交日期,按多久以前的方式显示
- %s 提交说明
- –since 限制显示输出的范围,
- 例如: git log –since=2.weeks 显示最近两周的提交
- 选项 说明
- -(n) 仅显示最近的 n 条提交
- –since, –after 仅显示指定时间之后的提交。
- –until, –before 仅显示指定时间之前的提交。
- –author 仅显示指定作者相关的提交。
- –committer 仅显示指定提交者相关的提交
复制代码 注意:
先打开git base , 再跳转到指定项目中,再执行以下git下令
一、 统计git提交次数: 所有人的所有提交次数,会展示所有的提交人 提交次数详情。
- git log | grep "^Author: " | awk '{print $2}' | sort | uniq -c | sort -k1,1nr
- # eg:非合并提交
- git log --no-merges | grep "^Author: " | awk '{print $2}' | sort | uniq -c | sort -k1,1nr
- # eg:合并提交
- git log --merges | grep "^Author: " | awk '{print $2}' | sort | uniq -c | sort -k1,1nr
- # eg:非合并提交 + 合并提交
- git log | grep "^Author: " | awk '{print $2}' | sort | uniq -c | sort -k1,1nr
复制代码 代码提交总数统计:
- git log --oneline | wc -l
复制代码 贡献者/代码提交人数统计:
- git log --pretty='%aN' | sort -u | wc -l
复制代码 检察仓库提交者排名前五
- git log --pretty='%aN' | sort | uniq -c | sort -k1 -n -r | head -n 5
复制代码 检察指定人代码提交次数
- git log --author="xuqiang18" --pretty='%aN' |sort |uniq -c | sort -k1 -n -r
复制代码 二、 统计时间内提交次数。
- git log --author=yourname --since="2017-08-01" --no-merges | grep -e 'commit [a-zA-Z0-9]*' | wc -l
- # eg:非合并提交
- git log --author="xuqiang18" --since="2020-08-01" --no-merges | grep -e 'commit [a-zA-Z0-9]*' | wc -l
- # eg:合并提交
- git log --author="xuqiang18" --since="2020-08-01" --merges | grep -e 'commit [a-zA-Z0-9]*' | wc -l
- # eg:非合并提交 + 合并提交
- git log --author="xuqiang18" --since="2020-08-01" | grep -e 'commit [a-zA-Z0-9]*' | wc -l
复制代码 三、 统计提交行数:根据1展示出详情,可以填入username。将展示该用户增加行数,删减行数,剩余行数。
检察git上个人代码量行数
- git log --author="xuqiang18" --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\n", add, subs, loc }' -
复制代码 统计所有成员的增删行数
- git log --format='%aN' | sort -u | while read name; do echo -en "$name\t"; git log --author="$name" --pretty=tformat: --numstat | awk '{ add += $1; subs += $2; loc += $1 - $2 } END { printf "added lines: %s, removed lines: %s, total lines: %s\n", add, subs, loc }' -; done
复制代码 四、其他
Search-作者
这个下令支持的搜索参数为提交的创建者和提交者,而且是支持正则表达式的,可以发挥的余地很多。
- //命令格式
- git log --author=<pattern>
- git log --committer=<pattern>
- //示例
- git log --author="小明"
- git log --author="小明\|小红"
复制代码 Search-时间
关于按时间搜索,支持的有很多类型,如下:
- //某个日期之后
- git log --since=<date>
- git log --after=<date>
- //某个日期之前
- git log --until=<date>
- git log --before=<date>
- //查出 2018.03.12 到 2018.03.18 期间的提交
- git log --since="2018.03.12" --until="2018.03.18"
复制代码 Search-提交信息
这个就锋利了,你可以搜索提交信息,也支持正表达式
- git log --grep=<pattern>
- //示例
- git log --grep='喜欢' --oneline
复制代码 Search-修改内容
一样平常情况下,我们想找一个提交,大多是为了某个修改去找,这个修改对应要么是详细的文件,要么是详细的修改的内容。放心,这个条件也支持。
文件
- //文件
- git log [\--] <path>…
- //示例
- git log --oneline -- 11.txt
复制代码 修改内容
这一部门其实是 Diff 的参数部门,有很多参数,这里列出两个。
- //查看某个字符串的变动历史提交
- git log -S<string>
- //查看某符合某一个正则表达式内容的变动历史提交
- git log -G<regex>
- //例子
- git log -S"喜欢你" --oneine
复制代码 Search-合并相关的提交 & 文件
工作中,分支之间的合并,每每不是 fast-forword,而是 recursive strategy merge 策略式合并,以是会在汗青中出现很多合并提交。运用下面的下令,你可以选择只看合并提交,或者非合并提交。
- //查看合并提交
- git log --merges
- //查看非合并提交
- git log --no-merges
复制代码 不幸发生了合并冲突,还可以用这个下令,可以快速找到冲突的文件。
- //查看发生合并冲突的文件
- git log --merge
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |