我只想看到上次提交时提交的文件和git提交时看到的列表完全一样。不幸的是

git "last commit" log

在谷歌中我什么都得不到。和

git diff HEAD^..HEAD

当然,这并不是我所需要的,因为它也会释放出改变的本质。


使用git显示:

git show --summary

这将显示已创建或删除的文件名,但不显示已更改的文件名。git show命令支持多种输出格式,用于显示关于提交的各种类型的信息。


$ git diff --name-only HEAD^..HEAD

or

$ git log --name-only HEAD^..HEAD

通过评论确定,似乎OP正在寻找

$ git log --name-status HEAD^..HEAD

这也非常接近从svn status或svn log -v得到的输出,许多从subversion转到git的人对这两个输出都很熟悉。

——name-status是这里的关键;正如其他人在这个问题中指出的那样,您可以使用git log -1、git show和git diff来获得相同类型的输出。就我个人而言,我倾向于在查看单个修订时使用git show <rev>。


git log -1 --stat

可以工作


git log -1 --name-status

为我工作。


到目前为止,最简单的命令是:

git show --name-only

因为它只列出了上次提交的文件,并没有给你全部的胆量

输出的一个例子是:

commit  fkh889hiuhb069e44254b4925d2b580a602
Author: Kylo Ren <Kylo@darkside.empire.gov>
Date:   Sat May 4 16:50:32 2168 -0700

Changed shield frequencies to prevent Millennium Falcon landing

 www/controllers/landing_ba_controller.js             
 www/controllers/landing_b_controller.js            
 www/controllers/landing_bp_controller.js          
 www/controllers/landing_h_controller.js          
 www/controllers/landing_w_controller.js  
 www/htdocs/robots.txt                        
 www/htdocs/templates/shields_FAQ.html       

我们不了解这些人

这显示了与上次提交相同的diffstat。


要查看最后一次提交:

git log -1

要查看最后2次提交:

git log -2

等等....


在执行多次提交或克隆/提取存储库之后,您可能希望看到已经进行了哪些提交。只需检查这些简单的解决方案,查看您的提交历史(从上次/最近的提交到第一次提交)。

对于最后一次提交,只需执行以下命令:git log -1。更多有趣的事情请看下面

To see the commit ID (SHA-1 checksum), Author name <mail ID>, Date along with time, and commit message - git log To see some more stats, such as the names of all the files changed during that commit and number of insertions/deletions. This comes in very handy while reviewing the code - git log --stat To see commit histories in some pretty formats :) (This is followed by some prebuild options)- If you have too many commits to review, this command will show them in a neat single line: git log --pretty=oneline To see short, medium, full, or even more details of your commit, use following, respectively - git log --pretty=short git log --pretty=medium git log --pretty=full git log --pretty=fuller You can even use your own output format using the format option - git log --pretty=format:"%an, %ae - %s" where %an - author name, %ae - author email, %s - subject of commit, etc.

这可以帮助您处理提交历史。欲了解更多信息,请点击这里。


查看上次提交的更改

git show HEAD

或者查看第二个最后提交的更改

git show HEAD~1

此外,只需将上面的“1”替换为所需的提交序列号。


另一种只列出文件的方法是使用: git diff-tree——no-commit-id——name-only -r HEAD^. 或者可以使用任意两个提交id


如果您正在讨论在执行了某个早期提交的git签出之后(并且在执行签出之前忘记写下HEAD的散列)找到最新和最大的提交,那么以上大多数方法都不会让您回到开始的地方。git log -[some #]只显示来自HEAD当前位置的日志,这并不一定是最后一次提交(项目的状态)。签出将断开HEAD并将其指向您签出的任何内容。

您可以查看整个git reflog,直到到达引用原始克隆的条目。顺便说一句,如果在克隆项目和执行签出之间进行了任何提交,这也不会起作用。否则,您可以希望本地机器上的所有提交都在服务器上,然后重新克隆整个项目。

希望这能有所帮助。


你可以跑

 git show --source

它显示了作者,日期,提交的消息和diff——git的所有更改文件在最近一次提交。


这个问题已经在上面回答了,上面说了git log /其他命令最后提交的文件名。如果有人想要查看上次提交中更改的内容(行差异),可以使用这个命令-

git show

这将自动显示上次提交时的行差。


在git中单独获得我的最后一个提交消息

git log——format=%B -n 1 $(git log -1——pretty=format:"%h") | cat -


如果您只想看到上次提交的文件名称

 git diff HEAD@{1} --name-only

如果您还想看到内容更改,请删除——name-only

如果你想比较当前状态和旧的提交,增加{n}


要查看以前的提交SHA

git log -n 2 --pretty=format:"%h" | tail -n 1

如果没有git: tail -n1 .git/logs/HEAD | cut -d' ' -f1,8-


比如git log -1——stat,你可以使用git show——stat。