我知道Git存储文件删除时间的信息,并且我能够检查各个提交以查看哪些文件已被删除,但是是否有一个命令可以在存储库的生命周期内生成每个已删除文件的列表?
当前回答
如果你只对当前删除的文件感兴趣,你可以使用这个:
git ls-files --deleted
如果你想删除它们(如果你没有使用“git rm”删除它们),将结果管道到xargs git rm
git ls-files --deleted | xargs git rm
其他回答
显示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
由于Windows没有grep命令,这在PowerShell中很适用:
git log --find-renames --diff-filter=D --summary | Select-String -Pattern "delete mode" | sort -u > deletions.txt
如果你想用换行符分隔两个名字,你可以像这样使用——name-only标志:
git diff --diff-filter=D --name-only <old-commit-hash> <new-commit-hash>
这将为您提供所有分支中被删除的所有文件的列表,按路径排序:
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。
引用这个Stack Overflow的答案。
这是一种非常简洁的方法,可以为每个被更改的文件获取更改类型(a:添加,M:修改,D:删除)。
git diff --name-status HEAD~1000
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的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之间的区别