我如何打印一份包含所有提交文件的简单列表?
尽管下面列出了这些文件,但它也包含了每个文件不需要的差异信息:
git show a303aa90779efdd2f6b9d90693e2cbbbe4613c1d
我如何打印一份包含所有提交文件的简单列表?
尽管下面列出了这些文件,但它也包含了每个文件不需要的差异信息:
git show a303aa90779efdd2f6b9d90693e2cbbbe4613c1d
当前回答
我经常使用更改后的别名。要设置它,请执行以下操作:
git config --global alias.changed 'show --pretty="format:" --name-only'
然后:
git changed (lists files modified in last commit)
git changed bAda55 (lists files modified in this commit)
git changed bAda55..ff0021 (lists files modified between those commits)
可能有用的类似命令:
git log --name-status --oneline (very similar, but shows what actually happened M/C/D)
git show --name-only
其他回答
尝试此命令获取名称并更改行数
git show --stat <commit-hash>
仅显示文件名
git show --stat --name-only <commit-hash>
要获取最后一个提交哈希,请尝试以下命令:
git log -1
上次提交时显示文件名和文件状态修改、创建或删除:
git log -1 --oneline --name-status <commit-hash>
或所有人
git log
有关更高级的git日志信息,请阅读以下文章:
Git日志格式字符串备忘单git日志备忘单
“gitshow--stat”(谢谢Ryan)和几个sed命令的组合应该可以为您减少数据:
git show --stat <SHA1> | sed -n "/ [\w]\*|/p" | sed "s/|.\*$//"
这将只生成已修改文件的列表。
使用标准的gitdiff命令(也适用于脚本编写):
git diff --name-only <sha>^ <sha>
如果还需要更改文件的状态:
git diff --name-status <sha>^ <sha>
这对于合并提交非常有效。
我使用此命令获取两个变更集之间的已修改文件列表:
git diff --name-status <SHA1> <SHA2> | cut -f2
Use
git log --name-status
这将显示提交id、消息、更改的文件以及是否修改、创建、添加或删除。有点像是一个万能的命令。