是否有可能从git stash中提取单个文件或文件的差异,而不弹出stash更改集?


当前回答

你可以用“git show stash@{0}”(或任何隐藏的数字是;参见“git藏匿列表”)。为单个文件提取diff的部分很容易。

其他回答

你可以用“git show stash@{0}”(或任何隐藏的数字是;参见“git藏匿列表”)。为单个文件提取diff的部分很容易。

要理解的最简单的概念(虽然可能不是最好的概念)是,您更改了三个文件,而希望保存一个文件。

如果你使用git stash来隐藏它们,git stash apply再次将它们带回来,然后git checkout f.c对有问题的文件有效地重置它。

当你想要unstash文件运行做一个git重置——硬,然后运行git stash apply再次,利用事实,git stash apply不清除差异从stash堆栈。

如果你使用git stash apply而不是git stash pop,它会将stash应用到你的工作树,但仍然保留stash。

完成此操作后,您可以添加/提交所需的文件,然后重置其余更改。

使用以下方法将对存储中的文件的更改应用到工作树。

git diff stash^! -- <filename> | git apply

这通常比使用git签出更好,因为您不会丢失创建存储后对文件所做的任何更改。

简短的回答

要查看整个文件:git show stash@{0}:<filename>

要查看diff: git diff stash@{0}^1 stash@{0}——<filename>