是否有可能从git stash中提取单个文件或文件的差异,而不弹出stash更改集?
当前回答
如果你使用git stash apply而不是git stash pop,它会将stash应用到你的工作树,但仍然保留stash。
完成此操作后,您可以添加/提交所需的文件,然后重置其余更改。
其他回答
你可以用“git show stash@{0}”(或任何隐藏的数字是;参见“git藏匿列表”)。为单个文件提取diff的部分很容易。
如果存储的文件需要与当前版本合并,请使用前面使用diff的方法。否则,您可能会使用git pop来解存储它们,git add fileWantToKeep来暂存您的文件,并执行git stash save——keep-index,用于存储除stage之外的所有内容。 记住,这种方法与前面的方法的不同之处在于它从stash中“弹出”文件。前面的答案保持git checkout stash@{0} - <filename>,所以它会根据你的需要。
$ git checkout stash@{0} -- <filename>
注:
确保在“——”和文件名参数后面有空格 将零(0)替换为您特定的藏匿编号。要获得收藏列表,使用: Git藏匿清单
基于Jakub narabbski的回答——更短的版本
简短的回答
要查看整个文件:git show stash@{0}:<filename>
要查看diff: git diff stash@{0}^1 stash@{0}——<filename>
如果你使用git stash apply而不是git stash pop,它会将stash应用到你的工作树,但仍然保留stash。
完成此操作后,您可以添加/提交所需的文件,然后重置其余更改。
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的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之间的区别