如何从最新提交中删除文件?
当前回答
这是我从比特桶回购中删除文件的工作,我最初将文件推送到分支。
git checkout origin/develop <path-to-file>
git add <path-to-file>
git commit -m "Message"
git push
其他回答
从git 2.23开始,您可以简单地使用以下命令:
git restore --staged <file>
现有的答案都是关于从上次提交中删除不需要的文件。
如果您想从旧提交(甚至推送)中删除不需要的文件,并且不想创建新提交,这是不必要的,因为执行以下操作:
使用查找您希望文件符合的提交;
git-log--图形--装饰--单行
使用签出提交
git checkout<commit_id><path_to_file>
如果要删除许多文件,可以多次执行此操作。
3.
gitcommit-am“删除不需要的文件”
4.
查找错误添加文件的提交的commit_id,让我们在这里说“35c23c2”
git rebase 35c23c2~1-i//注意:“~1”是必需的
此命令根据您的设置打开编辑器。默认值为vim。如果要更改全局git编辑器,请使用;
git-config--全局core.editor<editor_name>
5.
将最后一次提交(应该是“删除不需要的文件”)移动到错误提交的下一行(在我们的例子中是“35c23c2”),并将命令设置为fixup:
pick 35c23c2 the first commit
fixup 0d78b28 remove unwanted files
保存文件后你应该很好。
6.
要完成:
git push-f
如果不幸发生冲突,则必须手动解决。
我认为这里的其他答案是错误的,因为这是一个将错误提交的文件从上一次提交移回临时区域的问题,而不取消对它们所做的更改。这可以像Pariosh Singh建议的那样:
git reset --soft HEAD^
or
git reset --soft HEAD~1
然后重置不需要的文件,以便将它们从提交中删除(旧方法):
git reset HEAD path/to/unwanted_file
注意,自从Git 2.23.0以来,人们可以(以新的方式):
git restore --staged path/to/unwanted_file
现在再次提交,您甚至可以重复使用相同的提交消息:
git commit -c ORIG_HEAD
注意!如果您只想从上一次提交中删除一个文件,并将其保存在磁盘上,请阅读上面juzzlin的回答。
如果这是您最后一次提交,并且您希望从本地和远程存储库中完全删除该文件,您可以:
删除文件git-rm<file>带有修正标志的commit:gitcommit--修正
修正标志告诉git再次提交,但“合并”(不是合并两个分支的意思)这次提交与最后一次提交。
如注释中所述,在这里使用gitrm就像使用rm命令本身一样!
git reset—软HEAD~1git重置HEAD/file/to/deletegit rm—缓存/file/to/deletegitcommit--修改-m“您的消息”
重点是--修改
则可以:
git push-u原始主机
推荐文章
- 如何点Go模块的依赖在Go。Mod到回购中的最新提交?
- 为什么调用git分支——unset-upstream来修复?
- Windows git“警告:LF将被CRLF取代”,这是警告尾巴向后吗?
- git中的哈希冲突
- git可以自动在空格和制表符之间切换吗?
- Git暂存文件列表
- 如何将git配置存储为存储库的一部分?
- 如何修改GitHub拉请求?
- 如何在Github和本地删除最后n次提交?
- 我如何调试git/git-shell相关的问题?
- 错误:无法使用rebase进行拉取:您有未分阶段的更改
- Git隐藏未缓存:如何把所有未分期的变化?
- 真实的恶魔
- 如何从另一个分支获得更改
- Git:权限被拒绝(publickey)致命-无法从远程存储库读取。克隆Git存储库时