问题描述
我们需要找到在提交中修改的文件,以进行某些操作。
该笔记将记录:在 Git 中,如何获取在提交中被修改的文件。
解决方案
获取_在某次提交中_修改的文件:
# git diff-tree --no-commit-id --name-only -r 35285f296b68617c0198e770a6a5ca0a7b2db6e8 src/com/k4nz/blog/BlogStorage.groovy
使用 git log 命令查看:
# git log --name-status
commit 7723f2548c26655be9f282ba7a317c9192073c05 (grafted, HEAD -> master, origin/master, origin/HEAD)
Author: Sandeep Somavarapu <sasomava@microsoft.com>
Date: Sat Nov 28 10:11:01 2020 +0100
Fix #109406
A .devcontainer/README.md
A .devcontainer/cache/.gitignore
A .devcontainer/cache/before-cache.sh
...
仅显示修改的文件:
# git log --format=format: --name-only .devcontainer/README.md .devcontainer/cache/.gitignore .devcontainer/cache/before-cache.sh .devcontainer/cache/build-cache-image.sh .devcontainer/cache/cache-diff.sh .devcontainer/cache/cache.Dockerfile .devcontainer/cache/restore-diff.sh .devcontainer/devcontainer.json ...
参考文献
github - Getting a commit count for each file in a git repository - Stack Overflow
How to find the number of files changed from one commit to another in git - Stack Overflow
git - Which Jenkins Command to Get the List of Changed Files - Stack Overflow
git - How to list all the files in a commit? - Stack Overflow
本文详细介绍了如何在Git中获取指定提交中的修改文件,包括`git diff-tree`命令用于查看文件改动,以及`git log`的`--name-only`选项列出所有修改过的文件。通过实例展示了获取和过滤文件列表的方法,方便开发者进行后续操作和版本管理。
2065

被折叠的 条评论
为什么被折叠?



