如何从最新提交中删除文件?
当前回答
这是我从比特桶回购中删除文件的工作,我最初将文件推送到分支。
git checkout origin/develop <path-to-file>
git add <path-to-file>
git commit -m "Message"
git push
其他回答
将文件保存在本地(从gitcommit中删除)
如果要保留文件,可以使用--cached,如下所示:
git rm --cached filename
删除本地文件(并从gitcommit中删除)
否则,如果要删除文件,只需使用:
git rm filename
从git 2.23开始,您可以简单地使用以下命令:
git restore --staged <file>
如果尚未在服务器上推送更改,则可以使用
git reset --soft HEAD~1
它将重置所有更改并恢复为一次提交
如果您已经推动了更改,请按照@CharlesB回答的步骤操作
如果你不再需要那个文件,你可以
git rm file
git commit --amend
git push origin branch
如果要从以前的提交中删除文件,请使用筛选器
git filter-branch --prune-empty --index-filter 'git rm --ignore-unmatch --cached "file_to_be_removed.dmg"'
如果看到此错误:
无法创建新备份。refs/original中已存在以前的备份/强制使用-f覆盖备份
只需删除本地存储库上的refs备份
$ rm -rf .git/refs/original/refs
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的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之间的区别