git log ,查看提交次数和提交代码行数

这篇具有很好参考价值的文章主要介绍了git log ,查看提交次数和提交代码行数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

参考:

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命令

cd D:/project/xxxx

一、 统计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

不幸发生了合并冲突,还可以用这个命令,可以快速找到冲突的文件。文章来源地址https://www.toymoban.com/news/detail-849255.html

//查看发生合并冲突的文件
git log --merge

到了这里,关于git log ,查看提交次数和提交代码行数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Git统计个人提交代码行数

    在实际开发中,常常会想查看自己对于某个项目的贡献,管理者会查看项目下各成员的贡献,就需要使用到git的命令进行代码提交的统计。 进入到自己的项目文件中,右键点击Git Bash Here 打开后界面 这个统计是以当前所在分支为基准统计的,所以如果是迭代式的往后更迭,统

    2024年02月05日
    浏览(39)
  • git log 查看提交记录

    1. git log 查看提交历史记录 2. git log --oneline 或者 git log --pretty=oneline 以精简模式显示 3. git log --graph 以图形模式显示 4. git log --stat 显示文件更改列表 5. git log --author= \\\'name\\\' 显示某个作者的日志 6. git log -p filepath 查看某个文件的详细修改 7. git log -L start,end:filepath 查看某个文件某

    2023年04月22日
    浏览(33)
  • git使用-关于使用git命令统计整个项目的代码行数、提交者贡献统计等等

    可以使用以下命令来统计整个项目的代码行数: 这个命令会列出当前git仓库中所有的文件,然后将这些文件作为参数传递给 wc -l 命令,用于计算每个文件的行数。最终输出的结果是整个项目的代码行数。 请注意,这个命令只会计算代码文件的行数,不包括注释、空白行和其

    2024年02月09日
    浏览(52)
  • vscode插件——git分支管理、查看log提交的历史记录

    不辜负曾经那份热爱 当你觉得vscode用的不顺手时,就多找些插件叭❤ 一、Git Graph 1. 安装 选择红框的\\\"扩展\\\",搜索\\\"Git Graph\\\",直接安装即可。 2. 使用 打开源代码管理菜单,会发现右上角有个小分支图标,直接点击打开Git Graph。也可以直接从底部的Git Graph打开。 打开后,可查

    2024年02月11日
    浏览(63)
  • 解决使用git命令查看的某次提交时间与git log中显示的不一致的问题

    笔者的使用环境: Git 2.37.0.windows.1 TortoiseGit 2.11.0.0 IntelliJ IDEA 2022.3.1 (Ultimate Edition)   笔者遇到一个问题,需要查看 Git 某个提交(commit)的时间,但是发现使用 Git 命令查看的时间与命令 git log 、TortoiseGit、IntelliJ IDEA 中显示的不一致。而后三者显示的是一致的。   笔者查

    2024年02月02日
    浏览(39)
  • 如何通过TortoiseGit可视化工具查看Git管理的版本树和信息(工作树变更)内容

    黑色直线:master分支和基于master分支拉取基础分支都在这条线上,是一条直线。 其他线条:新开分支一定会增加一条线,但不一定每一条线分别代表一个分支。 注:如果一直是一个人,在同一个本地分支改的话,会一直是这条黑线。 即: 新的分支commit的差异,会产生新的支

    2024年02月04日
    浏览(97)
  • idea git只查看某个人提交的代码记录

    git插件只查看某个人提交的代码记录 右键显示弹框,选择Select in Git Log 展示的页面如下: 按住ctrl+enter完成查询

    2024年03月26日
    浏览(41)
  • git-新建分支与提交代码命令(附删除、切换、查看、合并分支)

    注意:在你新建分支之前,你应该在master分支,并且要保证你当前的是最新代码,要不然最后提交代码就会出问题。 新建分支并切换到该分支: 在新建的分支上写完代码之后,就可以提交代码了。此时应该在你新建的分支上 注意:有报错就先pull一下代码再提交  

    2024年02月14日
    浏览(50)
  • 将项目复制到新电脑之后, 无法通过git 进行拉取代码/查看历史提交记录等操作

    将项目代码整体打包到新环境(新电脑), 在idea/pycharm下载好git相关插件并打开项目之后, 通过git拉取代码失败(gitlab/git/gtee) 最近因工作原因需要讲电脑上的代码迁移到新电脑上, 但是将idea以及git插件等配置好之后, 打开项目, 发现无法查看之前的提交记录, 即使点击刷新也无法查

    2024年02月04日
    浏览(60)
  • vue2+datav可视化数据大屏(3)附自适应各分辨率的大屏框架git代码。

    接上一节所说,当我们将接口封装完了后,我们需要给大屏进行内容填充啦         📓 我们在ser-views文件夹下新建9个vue组件,如下图所示,我给编号为1到9          📓在组件里写入内容我是第一块...一次类推,一直到第九块         📓 在主容器中引入组件,并注册

    2024年04月14日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包