我知道Git存储文件删除时间的信息,并且我能够检查各个提交以查看哪些文件已被删除,但是是否有一个命令可以在存储库的生命周期内生成每个已删除文件的列表?
当前回答
git log --diff-filter=D --summary
请参见在Git存储库中查找并恢复已删除的文件
如果你不想要关于它们在哪个提交中被删除的所有信息,你可以在那里添加一个grep delete。
git log --diff-filter=D --summary | grep delete
其他回答
这将为您提供所有分支中被删除的所有文件的列表,按路径排序:
git log --diff-filter=D --summary | grep "delete mode 100" | cut -c 21- | sort > deleted.txt
工作在msysgit (2.6.1.windows.1)。注意,我们需要“删除模式100”,因为git文件可能已经被提交为模式100644或100755。
如果你想用换行符分隔两个名字,你可以像这样使用——name-only标志:
git diff --diff-filter=D --name-only <old-commit-hash> <new-commit-hash>
git log --diff-filter=D --summary
请参见在Git存储库中查找并恢复已删除的文件
如果你不想要关于它们在哪个提交中被删除的所有信息,你可以在那里添加一个grep delete。
git log --diff-filter=D --summary | grep delete
这就是你想要的,我认为:
git log --all --pretty=format: --name-only --diff-filter=D | sort -u
... 这是我直接从另一个答案中得到的。
这只打印文件路径,而不打印其他信息:
BETA.md
CONTRIBUTING.md
files/en-us/api/file_api/index.html
files/en-us/games/index/index.md
files/en-us/games/visual-js_game_engine/index.html
files/en-us/games/visual_js_ge/index.html
files/en-us/games/visual_typescript_game_engine/index.html
...
显示some_branch中所有已删除的文件
git diff origin/master...origin/some_branch --name-status | grep ^D
or
git diff origin/master...origin/some_branch --name-status --diff-filter=D
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别