如何从最新提交中删除文件?
当前回答
git checkout HEAD~ path/to/file
git commit --amend
其他回答
我将当前文件复制到另一个文件夹中,然后通过以下方式删除所有未推送的更改:
git reset --hard @{u}
然后把东西复制回去。提交,推。
这是我从比特桶回购中删除文件的工作,我最初将文件推送到分支。
git checkout origin/develop <path-to-file>
git add <path-to-file>
git commit -m "Message"
git push
现在,苹果已经将所有MacOS用户更新为zsh,正确的答案不再有效。
git reset --soft HEAD^
zsh: no matches found: HEAD^
您可以通过单引号防止shell将^视为特殊字符。
git reset --soft 'HEAD^'
或者,您可以在shell中禁用此行为。通过更新~/.zshrc
unsetopt nomatch
注意!如果您只想从上一次提交中删除一个文件,并将其保存在磁盘上,请阅读上面juzzlin的回答。
如果这是您最后一次提交,并且您希望从本地和远程存储库中完全删除该文件,您可以:
删除文件git-rm<file>带有修正标志的commit:gitcommit--修正
修正标志告诉git再次提交,但“合并”(不是合并两个分支的意思)这次提交与最后一次提交。
如注释中所述,在这里使用gitrm就像使用rm命令本身一样!
我只想补充上面的答案,因为我必须运行一个额外的命令:
git reset --soft HEAD^
git checkout origin/master <filepath>
干杯
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的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之间的区别