我知道我可以使用git diff命令来检查更改,但是,据我所知,它是基于目录的。这意味着它给出当前目录中所有文件的所有更改。
如何只检查一个特定文件中的更改?比如说,我已经修改了文件file_1。rb, file_2。rb,……, file_N。rb,但是我只对文件file_2.rb中的更改感兴趣。我如何检查这些更改(在我提交之前)?
我知道我可以使用git diff命令来检查更改,但是,据我所知,它是基于目录的。这意味着它给出当前目录中所有文件的所有更改。
如何只检查一个特定文件中的更改?比如说,我已经修改了文件file_1。rb, file_2。rb,……, file_N。rb,但是我只对文件file_2.rb中的更改感兴趣。我如何检查这些更改(在我提交之前)?
当前回答
另一种方法(在这个SO回答中提到)将在终端中保存历史记录,并为您提供文件本身的非常深入的跟踪记录:
Git日志——follow -p——file
这将显示文件的整个历史(包括重命名以外的历史和每次更改的差异)。 换句话说,如果名为bar的文件曾经被命名为foo,那么git log -p bar(没有——follow选项)将只显示文件重命名之前的历史记录——当文件被命名为foo时,它不会显示文件的历史记录。使用git log——follow -p bar将显示文件的整个历史记录,包括当它被称为foo时对文件的任何更改。
其他回答
你可以使用tig:
Sudo apt安装tig
你只需在控制台输入:tig
你可以有这样的东西,你可以浏览每一行代码的提交和本地更改
或者如果你喜欢使用自己的gui工具:
git difftool ./filepath
你可以根据这篇文章来设置你的gui工具: 我如何查看'git diff'输出与一个可视化的diff程序?
你可以执行
git status -s
这将显示修改后的文件名,然后通过复制感兴趣的文件路径,您可以使用git diff看到更改
git diff <filepath + filename>
你也可以试试
git show <filename>
对于提交,git show将显示日志消息和文本差异(在您的文件和提交的文件版本之间)。
你可以查看git show Documentation了解更多信息。
Git diff文件名
会给你 添加行as + 删除行如下: