使用 Subversion,我可以使用TortoiseSVN查看文件的历史记录/日志。
我怎样才能用 Git 做到这一点?
我只是在寻找特定文件的历史记录,然后能够比较不同的版本。
用于git log
查看提交历史。每个提交都有一个相关的修订说明符,它是一个哈希键(例如14b8d0982044b0c49f7a855e396206ee65c0e787
和b410ad4619d296f9d37f0db3d0ff5b9066838b39
)。要查看两个不同提交之间的差异,请使用两个提交git diff
的修订说明符的前几个字符,如下所示:
# diff between commits 14b8... and b410...
git diff 14b8..b410
# only include diff of specified files
git diff 14b8..b410 path/to/file/a path/to/file/b
如果您想了解从提交到提交所发生的所有差异,请使用git log
或git whatchanged
使用 patch 选项:
# include patch displays in the commit history
git log -p
git whatchanged -p
# only get history of those commits that touch specified paths
git log path/a path/b
git whatchanged path/c path/d
我喜欢用gitk name_of_file
这显示了每次提交时文件发生的更改的一个很好的列表,而不是显示对所有文件的更改。更容易追踪发生的事情。
我最喜欢的是git log -p <filename>
,它将为您提供给定文件的所有提交的历史记录以及每个提交的差异。
许多 Git 历史浏览器,包括git log
(和 'git log --graph')、gitk(在Tcl/Tk中,是 Git 的一部分)、QGit(在 Qt 中)、tig(到 Git 的文本模式接口,使用ncurses)、Giggle(在GTK+)、TortoiseGit 和git-cheetah支持路径限制(例如,gitk path/to/file
)。
当然,如果你想要尽可能接近 TortoiseSVN 的东西,你可以使用TortoiseGit。
git log --all -- path/to/file
应该管用
TortoiseGit还提供了一个命令行工具来查看文件的历史。使用PowerShell:
C:\Program` Files\TortoiseGit\bin\TortoiseGitProc.exe /command:log /path:"c:\path\to\your\file.txt"