如何查看单个文件的历史记录以及更改内容的完整详细信息?

git-log--[filename]显示文件的提交历史,但如何查看更改的文件内容?


当前回答

SmartGit:

在菜单中启用以显示未更改的文件:查看/显示未更改文件右键单击文件并选择“日志”或按“Ctrl-L”

其他回答

我写git回放就是为了这个目的

pip install git-playback
git playback [filename]

这样既可以在命令行中显示结果(如gitlog-p),也可以使用箭头键(如gitk)逐步完成每次提交。

对于图形视图,请使用gitk:

gitk [filename]

要跨文件重命名跟随文件,请执行以下操作:

gitk --follow [filename]

要获取特定文件的所有提交,请使用以下命令:

git rev list HEAD--单行文件名


例如

git rev list HEAD--单行index.html

输出

7a2bb2f update_index_with_alias
6c03e56 update_changes
e867142 Revert "add_paragraph"

如果要查看对文件所做的更改

git-log-p文件名

查看gif图像

我大概是想知道OP开始时的位置,寻找一些简单的东西,让我可以使用gitdifftool和vimdiff从特定提交开始查看repo中文件的更改。我对我找到的答案不太满意,所以我把这个gitincremental reporter(gitincrement reporter)脚本放在一起,它对我很有用:

#!/usr/bin/env bash

STARTWITH="${1:-}"
shift 1

DFILES=( "$@" )

RunDiff()
{
        GIT1=$1
        GIT2=$2
        shift 2

        if [ "$(git diff $GIT1 $GIT2 "$@")" ]
        then
                git log ${GIT1}..${GIT2}
                git difftool --tool=vimdiff $GIT1 $GIT2 "$@"
        fi
}

OLDVERS=""
RUNDIFF=""

for NEWVERS in $(git log --format=format:%h  --reverse)
do
        if [ "$RUNDIFF" ]
        then
                RunDiff $OLDVERS $NEWVERS "${DFILES[@]}"
        elif [ "$OLDVERS" ]
        then
                if [ "$NEWVERS" = "${STARTWITH:=${NEWVERS}}" ]
                then
                        RUNDIFF=true
                        RunDiff $OLDVERS $NEWVERS "${DFILES[@]}"
                fi
        fi
        OLDVERS=$NEWVERS
done

调用时不带任何参数,这将从回购历史的开始处开始,否则它将从您提供的任何缩写提交哈希开始,并继续到现在-您可以随时使用ctrl-C退出。第一个参数之后的任何参数都将限制差异报告仅包括这些参数中列出的文件(我认为这是OP想要的,我建议所有项目都使用这些文件,但小项目除外)。如果您正在检查对特定文件的更改,并希望从头开始,则需要为arg1提供空字符串。如果你不是vim用户,你可以用你喜欢的diff工具替换vimdiff。

行为是在发现相关更改时输出提交注释,并开始为每个更改的文件提供vimdiff运行(这是gitdifftool行为,但它在这里起作用)。

这种方法可能很幼稚,但在这里和一篇相关文章中查看了许多解决方案,其中许多涉及在我没有管理员权限的系统上安装新工具,界面有自己的学习曲线。上面的脚本做了我想做的事情,但没有处理这些。当我需要更复杂的东西时,我会研究这里的许多优秀建议,但我认为这是对OP的直接响应。

如果您正在使用Git GUI(在Windows上):

在“存储库”菜单下,您可以使用“可视化大师的历史记录”。

突出显示顶部窗格中的提交和右下角的文件,您将在左下角看到该提交的差异。