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


当前回答

简短的回答

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

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

其他回答

$ git checkout stash@{0} -- <filename>

注:

确保在“——”和文件名参数后面有空格 将零(0)替换为您特定的藏匿编号。要获得收藏列表,使用: Git藏匿清单

基于Jakub narabbski的回答——更短的版本

如果存储的文件需要与当前版本合并,请使用前面使用diff的方法。否则,您可能会使用git pop来解存储它们,git add fileWantToKeep来暂存您的文件,并执行git stash save——keep-index,用于存储除stage之外的所有内容。 记住,这种方法与前面的方法的不同之处在于它从stash中“弹出”文件。前面的答案保持git checkout stash@{0} - <filename>,所以它会根据你的需要。

在git stash manpage上,你可以读到(在“讨论”部分,就在“选项”描述之后):

存储被表示为一个提交,其树记录对象的状态 工作目录,它的第一个父目录是HEAD时的提交 Stash应运而生。

所以你可以把stash(例如,stash@{0}是第一个/最上面的stash)作为合并提交,并使用:

$ git diff stash@{0}^1 stash@{0} -- <filename>

解释:stash@{0}^1表示给定stash的第一个父对象,正如上面的解释所述,它是在提交时将更改隐藏起来。我们使用这种形式的“git diff”(两次提交),因为stash@{0} / refs/stash是一个合并提交,我们必须告诉git我们想要对哪个父文件进行diff。更神秘的:

$ git diff stash@{0}^! -- <filename>

应该也可以工作(参见git rev-parse manpage对rev^!语法,在“指定范围”部分)。

同样地,你可以使用git checkout将一个文件从stash中检出:

$ git checkout stash@{0} -- <filename>

或者将其保存在另一个文件名下:

$ git show stash@{0}:<full filename>  >  <newfile>

or

$ git show stash@{0}:./<relative filename> > <newfile>

(注意这里<full filename>是一个文件相对于一个项目的顶部目录的完整路径名(想想:相对于stash@{0}))。


您可能需要保护stash@{0}不受shell扩展的影响,即使用“stash@{0}”或“stash@{0}”。

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

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

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

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