我对一个文件进行了更改,再加上一个新文件,我想在切换到另一个任务时使用git stash将它们保存起来。但是git stash本身只存储对现有文件的更改;新文件仍保留在我的工作树中,打乱了我未来的工作。我如何保存这个未跟踪的文件?
当前回答
我可以通过以下方式来隐藏未跟踪的文件:
git stash save "tracked files I'm working on"
git stash save -u "untracked files I'm trying to stash"
git stash pop stash@{1}
最后一个弹出隐藏的跟踪文件,从而只留下未跟踪的文件。
其他回答
在gitbash中,通过使用命令实现未跟踪文件的隐藏
git stash --include-untracked
# or
git stash -u
http://git-scm.com/docs/git-stash
gitstash从工作区中删除任何未跟踪或未提交的文件。您可以使用以下命令恢复git存储
git stash pop
这将把文件放回本地工作区。
我的经历
我不得不对gitIgnore文件进行修改,以避免.classpath和.project文件移动到远程存储库中。到目前为止,我不能在远程回购中移动这个修改过的.gitIgnore。
.classpath和.project文件对于eclipse很重要,eclipse是我的java编辑器。
首先,我有选择地添加了其余的文件,并提交了暂存。但是,除非修改的.gitIgnore字段和未跟踪的文件(即.project和.classpath)未被隐藏,否则无法执行最终推送。
我用过
git stash
用于隐藏已修改的.gitIgnore文件。
对于存放.classpath和.project文件,我使用
git stash --include-untracked
它从我的工作区删除了这些文件。缺少这些文件会影响我在eclipse中处理工作位置的能力。我继续完成将提交的文件推送到远程的过程。成功完成后,我使用
git stash pop
这将相同的文件粘贴回我的工作区。这给了我在eclipse中处理同一项目的能力。希望这能消除误解。
2020年更新答案
我很惊讶,这个页面上没有其他答案提到git stash push。
这篇文章帮助我理解了:
命令gitstash是gitstashpush的简写。在此模式下,不允许使用非选项参数来防止拼写错误的子命令生成不需要的隐藏项。这个命令git stash save还有另一个别名,它已被弃用,取而代之的是git stass push。默认情况下,git在执行隐藏时忽略未跟踪的文件。如果需要将这些文件添加到stash中,可以使用-u选项,告诉git包括未跟踪的文件。如果指定了-a选项,也可以添加忽略的文件-a将包括未跟踪和忽略的文件。
我关心命名我的存储,我希望它们包含未跟踪的文件,所以我最常用的命令是:git stash push-u-m“whatIWantToNameThisStash”
将文件添加到索引:
git add path/to/untracked-file
git stash
索引的全部内容,加上对现有文件的任何未标记的更改,都将被放入存储库。
如果您想隐藏未跟踪的文件,但保留索引文件(例如,您要提交的文件),只需在-u中添加-k(保留索引)选项
git stash -u -k
在VS 2019和更高版本中提供Stashing。
转到Git更改窗口Ctrl+Alt+F7现在按下“全部提交”或“提交阶段”按钮附近的下拉键,查看隐藏选项
如果您想隐藏未跟踪的文件,如Git忽略的文件或未包含在项目中的文件,请选择此选项
阅读以下答案,了解Visual studio中Git存储的完整用法:https://stackoverflow.com/a/69905607/4391394
推荐文章
- 在单个文件中重新启动/撤消冲突解决方案
- Visual Studio代码如何解决合并冲突与git?
- 无法推送到远程分支,无法解析到分支
- Git:如何将数据库重置为特定的提交?
- 如何在合并期间使用Git和命令行保存本地文件或远程文件?
- 能够用一个命令推到所有git遥控器?
- 重新基于Git合并提交
- 忽略已经签入目录的内容?
- 如何从windows cmd保存git提交消息?
- (Mac) -bash: __git_ps1:命令未找到
- 如何删除多个已删除的文件在Git仓库
- 使用vimdiff查看所有' git diff '
- 如何拉特定的目录与git
- 本地存储库中的文件与源文件之间的差异
- 将Git存储库内容移动到另一个存储库,保存历史记录