在Git中是否有可能恢复已提交的文件?我已经将一个提交到GitHub,然后我意识到有一个文件我不想被推送(我还没有完成更改)。
当前回答
如果你想从远程repo中删除文件,首先用——cache选项从项目中删除它,然后推送它:
git rm --cached /path/to/file
git commit -am "Remove file"
git push
(即使文件在一些提交之前添加到远程repo,也可以工作) 记得在.gitignore中添加你不想推送的文件扩展名。
其他回答
如果你想从远程repo中删除文件,首先用——cache选项从项目中删除它,然后推送它:
git rm --cached /path/to/file
git commit -am "Remove file"
git push
(即使文件在一些提交之前添加到远程repo,也可以工作) 记得在.gitignore中添加你不想推送的文件扩展名。
将文件重置为正确的状态,提交并再次推送。
如果你确定还没有人获取你的更改,你可以在提交时使用——amend来修改你之前的提交(即重写历史),然后push。不过,我认为在push时必须使用-f选项来强制push。
使用 Git rm——缓存/路径/到/文件 然后添加、提交和推送。就像上面的答案,但你需要使用缓存而不是缓存。
我遵循这些步骤[它经常发生在我,特别是在节点模块文件夹]
1-去日志
2- git 还原 04409a858709c82fbf9eae7559d6ae9c34b6fbe6
换一个你承诺的号码
<它将是像04409a858709c82fbf9eae7559d6ae9c34b6fbe6>这样的长数字
3-git推
这对我来说很有效,但请记住,这里有一个技巧,你的第一个提交将是列表中的最后一个,所以请检查日期和提交消息。
从我的终端查看这张图片
获取上次提交的哈希码。 git日志 恢复提交 Git恢复<hash_code_from_git_log> 推动改变 git推
在GHR退房。你可能会得到任何你需要的,希望这是有用的
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- 在GitHub上有一个公共回购的私人分支?
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- 只用GitHub动作在特定分支上运行作业
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 是否有一个链接到GitHub下载文件的最新版本的存储库?