git 统计两个不同版本代码修改行数

sourceTree 点击命令行模式,输入以下命令:

1、统计标签tag1、tag2之间的代码修改的行数

git log tag1..tag2 --pretty=tformat: --numstat | gawk '{ add += $1 ; subs += $2 ; loc += $1 + $2 } END { printf "added lines: %s removed lines : %s total lines: %s\n",add,subs,loc }'

 

mac升级最新系统后,取消了gawk,改用awk命令

git log tag1..tag2 --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 }'

 

输出:added lines: 12174 removed lines : 8284 total lines : 20458

 

2、统计某个作者修改的行数

git log --author="$(git config --get user.name)" --pretty=tformat: --numstat | gawk '{ add += $1 ; subs += $2 ; loc += $1 + $2 } END { printf "added lines: %s removed lines : %s total lines: %s\n",add,subs,loc }'

 

3、统计两个日期之间的修改的行数

git log --pretty=tformat: --since ==2018-4-25 --until=2018-6-27 --numstat | gawk '{ 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

 

 

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 log --until=1.minute.ago // 一分钟之前的所有 log git log --since=1.day.ago //一天之内的log git log --since=1.hour.ago //一个小时之内的 log git log --since=`.month.ago --until=2.weeks.ago //一个月之前到半个月之前的log git

log --since ==2013-08.01 --until=2013-09-07 //某个时间段的 log   git blame

看看某一个文件的相关历史记录

       例如:git blame index.html --date short

 

统计 Git 仓库中 `master` 分支两个版本之间的代码差异,可以使用 `git diff` 命令来获取差异信息,并结合一些选项来统计具体的代码变化,例如新增、修改和删除的行数。 ### 比较两个版本之间的代码差异统计 可以使用以下命令来比较两个提交(commit)之间的差异,并统计代码变化的行数: ```bash git diff --stat commit-id1 commit-id2 ``` 其中 `commit-id1` 和 `commit-id2` 是你要比较两个版本的提交哈希值。该命令会列出所有发生变化的文件,并显示每个文件的新增、删除和修改行数。 例如: ```bash git diff --stat abc1234 def5678 ``` 输出示例: ``` src/main.py | 15 +++++++++------ src/utils.py | 8 ++++++++ 2 files changed, 23 insertions(+), 6 deletions(-) ``` 这表明两个文件发生了变化,总共新增了 23 行,删除了 6 行。 ### 获取详细的代码差异统计 如果需要更详细的统计信息,包括每行代码的具体变更,可以使用以下命令: ```bash git diff commit-id1 commit-id2 ``` 此命令会显示两个提交之间的所有代码变更,包括具体行的添加和删除。 ### 获取所有差异文件的列表 如果只需要获取两个版本之间发生变化的文件列表,可以使用以下命令: ```bash git diff --name-only commit-id1 commit-id2 ``` 该命令会列出所有在两个提交之间发生变化的文件名。 ### 导出差异文件并打包 如果需要将两个版本之间的差异文件导出并打包,可以使用以下命令: ```bash git archive -o ../update.zip HEAD $(git diff --name-only commit-id1 commit-id2) ``` 该命令会将两个版本之间发生变化的文件打包成一个 ZIP 文件,便于部署或分享。 ### 使用 `git log` 查看版本之间的提交差异 如果你想查看两个版本之间有哪些提交记录,可以使用以下命令: ```bash git log commit-id1..commit-id2 ``` 该命令会列出 `commit-id1` 和 `commit-id2` 之间的所有提交记录,包括提交哈希、作者、日期和提交信息。 ### 使用 `git diff` 统计代码变化的总行数 如果你想统计整个仓库在两个版本之间总的代码变化行数,可以结合 `git diff` 和 `wc` 命令: ```bash git diff --shortstat commit-id1 commit-id2 ``` 该命令会输出类似以下的信息: ``` 15 files changed, 123 insertions(+), 45 deletions(-) ``` 这表示在两个版本之间,共有 15 个文件发生了变化,新增了 123 行代码,删除了 45 行代码。 ### 总结 通过 `git diff` 的不同选项,可以灵活地统计 `master` 分支两个版本之间的代码变化情况,包括文件级别的变化、详细的代码变更、差异文件的打包导出等[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值