使用gitlog时,如何按用户进行筛选,以便只看到该用户的提交?


当前回答

如果使用GitHub:

转到分支机构单击提交

它将以以下格式显示列表

branch_x: < comment> 
author_name committed 2 days ago

看到个人作者的承诺;单击authorname,在那里您可以看到该作者在该分支上的所有提交

其他回答

cat | git log --author="authorName" > author_commits_details.txt

这将以文本格式提供提交。

我的案例:我使用的是源代码树,我遵循了以下步骤:

按下CRL+3已更改下拉列表作者键入名称“Vinod Kumar”

通过在.bashrc文件中添加这个小片段,以彩色显示x用户的n个日志。

gitlog() {
    if [ "$1" ] && [ "$2" ]; then
       git log --pretty=format:"%h%x09 %C(cyan)%an%x09 %Creset%ad%x09 %Cgreen%s" --date-order -n "$1" --author="$2"
    elif [ "$1" ]; then
       git log --pretty=format:"%h%x09 %C(cyan)%an%x09 %Creset%ad%x09 %Cgreen%s" --date-order -n "$1"
    else
        git log --pretty=format:"%h%x09 %C(cyan)%an%x09 %Creset%ad%x09 %Cgreen%s" --date-order
    fi
}

alias l=gitlog

要显示Frank的最后10次提交:

l 10弗兰克

要显示任何人的最后20次提交:

l 20

一种可能的替代方法是使用名为mergestat的工具,该工具允许您针对repo中的提交历史运行SQL查询(除其他外)。

mergestat "SELECT * FROM commits WHERE author_name LIKE '%Jon%'"

它有点冗长,但可以提供灵活性,以通用的方式具体查找您要查找的内容。

例如,过滤掉合并提交,仅显示过去一年中特定作者的提交:

mergestat "SELECT * FROM commits WHERE author_name LIKE '%Jon%' WHERE author_when > DATE('now', '-1 year') AND parents < 2"

完整披露:我是项目的维护者:)

git help log

为您提供gitlog的手册页。按/,然后键入“author”,然后按Enter键,在那里搜索“作者”。键入“n”几次以进入相关部分,其中显示:

git log --author="username"

正如已经建议的那样。

注意,这将为您提供提交的作者,但在Git中,作者可以是与提交者不同的人(例如,在Linux内核中,如果您以普通用户身份提交补丁,则可能由其他管理用户提交)?有关详细信息)

大多数时候,人们所说的用户既是提交者,也是作者。