Git 如何撤消一个";吉特加上;保留以前的阶段版本?(索引是否有历史记录?)

Git 如何撤消一个";吉特加上;保留以前的阶段版本?(索引是否有历史记录?),git,pre-commit,unstage,Git,Pre Commit,Unstage,我有一个问题类似于,但有一个重要区别: 背景: 我正在运行一些生成文件的代码,这些文件完成后将添加到我的存储库中。生成文件的代码是新代码,并且不断变化,所以我有时会多次运行它,并进行更改 在此过程中,我将生成的文件添加到索引中,这样它们就可以在最后进行一次大型提交了。这还允许我检查对代码的更改是否会在输出中产生更改,如果是,这些更改是什么。但是我意外地在一个文件上运行了另一个git add,该文件出现在要提交的更改部分(作为新文件)和未提交的更改部分(作为修改的)。我本想在上面运行git dif

我有一个问题类似于,但有一个重要区别:

背景:

我正在运行一些生成文件的代码,这些文件完成后将添加到我的存储库中。生成文件的代码是新代码,并且不断变化,所以我有时会多次运行它,并进行更改

在此过程中,我将生成的文件添加到索引中,这样它们就可以在最后进行一次大型提交了。这还允许我检查对代码的更改是否会在输出中产生更改,如果是,这些更改是什么。但是我意外地在一个文件上运行了另一个git add,该文件出现在
要提交的更改
部分(作为
新文件
未提交的更改
部分(作为
修改的
)。我本想在上面运行git diff,但我滑了一下,重新添加了它,所以现在我没有一种方法来进行diff(我知道),所以

问题:

是否有方法仅撤消上一次登台操作,这样以前添加的版本仍然/再次出现在索引中,修改后的文件将再次出现在我的工作树中,以便我可以区分它

所有这些都不是承诺或任何事情,因为我的目标是在完成这一小轮开发后一起承诺。我真的很喜欢git可以在提交新文件之前向我显示对它们的更改。。。但是我错过了一个机会,现在想知道是否有办法把它弄回来


到目前为止,我所查找的内容似乎能够让我返回到上次提交(没有文件)或文件的当前状态(无论如何,我已经这样做了),但不是从索引转到以前版本的中间,这从来不是提交的一部分。任何关于这是否可能的提示(即使是不可能的可靠答案,最好是解释为什么会出现这种情况)都将不胜感激。

没有直接的方法可以获得文件的最后阶段版本。索引文件没有版本控制,这就是您应该使用提交的目的。将来你可以考虑更多的临时提交(例如用<代码>提交-修改< /代码>),然后至少你以前的版本将在你的重新FLUG中(例如<代码> GIT日志-G/<代码>)。
但是,所有文件的所有暂存版本都将添加到git对象数据库中。您应该能够使用git fsck--lost-found找到它们。这将把所有“悬空”的blob写入
.git/lost-found/other
。不幸的是,它们没有任何特定的顺序或原始文件名,但任何丢失的blob都应该在其中的某个位置。

如果您能够识别添加的时间窗口,则repo对象文件上的时间戳会有所帮助。如果您能够区分所要添加的内容,“此添加之前的最近一次添加”会变得非常简单。是的,我同意一直运行git commit不会伤害你。这就是git的意图。谢谢。至于频繁的提交,这只发生在几秒钟之内,真的。。。我相当频繁地进行提交,尽管做得更频繁,而且使用--amend可能很有意义。失物招领选项也有潜在的帮助,所以谢谢!我已经离开了,但听起来这可能会给我当时想要的东西。谢谢