从 Git 提交中删除文件

这篇具有很好参考价值的文章主要介绍了从 Git 提交中删除文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

问:

如何从最新提交中删除文件?

答1:

huntsbot.com – 程序员副业首选,一站式外包任务、远程工作、创意产品分享订阅平台。

我认为这里的其他答案是错误的,因为这是一个将错误提交的文件从上一次提交移回暂存区域的问题,而不取消对它们所做的更改。这可以像 Paritosh Singh 建议的那样完成:

git reset --soft HEAD^ 

或者

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  

谢谢你。值得补充的是,如果您已经推送了之前的(错误的)提交,现在尝试 git push 修复您的存储库,它会抱怨 Updates were rejected because the tip of your current branch is behind its remote counterpart.。如果您确定要推送它们(例如,它是您的分叉),那么您可以使用 -f 选项来强制推送,例如 git push origin master -f。 (不要对其他人从中获取的上游仓库执行此操作)

git reset --soft HEAD^ 是我最常用的撤消操作

所有答案顶部的@PabloFernandez 是三个选项卡,可让您控制答案的顺序:活动、最旧和投票。我的猜测是你的设置为最旧的。即使接受的答案仍位于顶部,也将其切换为投票,此答案将排在第二位。

我对 git reset 了解很多,但想要一种方法来“就地”影响现有的提交。我刚刚了解了 git commit -C。所以对我来说,我想要的是你的确切配方,再加上一个步骤,“再次提交新的”拼写为 git commit -C [hash of original HEAD commit from first step]。

请记住进行实际提交,而不是修改。如果你这样做,它将修改以前的提交。 - 哎呀

答2:

huntsbot.com洞察每一个产品背后的需求与收益,从而捕获灵感

注意!如果您只想从之前的提交中删除一个文件并将其保存在磁盘上,请阅读上面的 juzzlin’s answer。

如果这是您的最后一次提交,并且您想从本地和远程存储库中完全删除该文件,您可以:

删除带有修改标志的文件 git rm commit: git commit --amend

修改标志告诉 git 再次提交,但是“合并”(不是在合并两个分支的意义上)这个提交与最后一次提交。

正如评论中所述,在这里使用 git rm 就像使用 rm 命令本身!

您还可以使用 git rm --cached 将文件保存在磁盘上

警告那些浏览这个答案的人:确保你想删除文件(就像已经消失了一样!),而不仅仅是从提交列表中删除它。

添加到其他人所说的内容(并且更容易记住不要这样做,除非您真的想这样做):git 命令中的 rm 正在 执行 {1 } 本身就可以!

请注意,文件仍然可以恢复,如果您改变主意,git commit --amend 之前的提交仍然存在,例如可以通过 git reflog 找到。所以它并不像其他评论所说的那么糟糕。

推送时需要强制推送:如果使用 --amend,则为 git push -f。

答3:

huntsbot.com全球7大洲远程工作机会,探索不一样的工作方式文章来源地址https://www.toymoban.com/news/detail-432519.html

现有答案都在谈论从上次提交中删除不需要的文件。

如果您想从旧提交(甚至推送)中删除不需要的文件并且不想创建新的提交,这是不必要的,因为该操作:

使用 ; 找到您希望文件符合的提交

git log --graph --decorate --oneline

使用签出该提交

git checkout <commit_id> <path_to_file>

如果要删除许多文件,可以多次执行此操作。

git commit -am “remove unwanted files”

找到错误添加文件的提交的commit_id,这里说“35c23c2”

git rebase 35c23c2~1 -i // notice: “~1” is necessary

此命令根据您的设置打开编辑器。默认是 vim。如果要更改全局 git 编辑器,请使用;

git config --global core.editor <editor_name>

将最后一次提交(应该是“删除不需要的文件”)移动到错误提交的下一行(在我们的例子中是“35c23c2”),并将命令设置为 fixup:

pick 35c23c2 the first commit
fixup 0d78b28 remove unwanted files

保存文件后你应该很好。

完成 :

git push -f

如果不幸遇到冲突,则必须手动解决。

如果您想实际从存储库(而不是文件系统)中删除文件,而不是仅仅将它们恢复到以前的版本,那么请不要执行第 1 步,而是执行 git rm --cached 。

等等,您可以随意在交互式变基文件周围移动提交吗?

你完全可以,但你可能(或可能不会)发生冲突。

通过将 --fixup=35c23c2 添加到 git commit 命令可以使此过程更容易一些。这将自动将提交设置为所需提交的修复,因此您无需在 rebase 中指定它。此外,如果您将 --autosquash 添加到 git rebase 命令,git 会自动将您的提交移动到正确的位置,因此您无需在交互式 rebase 中执行任何操作 - 只需保存结果(这意味着您不需要t 甚至需要 -i 标志,尽管我还是喜欢使用它来确保一切看起来都符合我的预期)。

没用,在检查特定的提交和文件后它什么也没做

答4:

与HuntsBot一起,探索全球自由职业机会–huntsbot.com

正如接受的答案所示,您可以通过重置整个提交来做到这一点。但这是一种相当严厉的方法。一种更简洁的方法是保留提交,并简单地从中删除更改的文件。

git reset HEAD^ -- path/to/file
git commit --amend --no-edit

git reset 将按照上次提交中的方式获取文件,并将其暂存到索引中。工作目录中的文件保持不变。 git commit 然后将提交并将索引压缩到当前提交中。

这实质上采用了先前提交中的文件版本并将其添加到当前提交中。这导致没有净变化,因此文件被有效地从提交中删除。

对于仅删除单个文件而不彻底检查整个提交,这是一个更好的答案。

这与此答案完全相同:D stackoverflow.com/a/27340569/1623984

@ThatsAMorais 确实:-)。我想知道这个问题是否与另一个问题合并,这就是为什么我没有看到它。或者,也许我只是个盲人。无论哪种情况,我认为我倾向于离开它,因为它似乎更受欢迎(也许人们更喜欢简短而直接的答案)。

无论如何离开它! :) 我们显然有正确的想法,目的是提供帮助。我认为合并是一个很好的理论。

不错的答案,但是您可能需要注意一个问题:如果您当前暂存了任何添加或删除的文件,它们将通过 git commit --amend --no-edit 命令添加到提交中。不知道为什么会这样,但它只是咬了我一口。

答5:

huntsbot.com全球7大洲远程工作机会,探索不一样的工作方式

如果您尚未在服务器上推送更改,则可以使用

git reset --soft HEAD~1

它将重置所有更改并恢复为一次提交

如果您已推送更改,请按照@CharlesB 回答的步骤操作

-1 git reset 从暂存区删除更改发生的文件,此处更改已提交

好的,但我会继续投反对票,因为这不是 OP 想要的:) 抱歉

好的,对我来说很好,但为什么对手不想要这个。问题是什么?

没什么大不了的,但是因为 OP 想要从上次提交中删除不需要的文件,并且它只是重置为提交前的状态。你仍然必须重做提交。

@Aris 使用 查看更改

答6:

HuntsBot周刊–不定时分享成功产品案例,学习他们如何成功建立自己的副业–huntsbot.com

使用 rm 删除文件将删除它!

您总是在 git 中添加提交而不是删除,因此在这种情况下,将文件返回到第一次提交之前的状态(如果文件是新文件,这可能是删除 ‘rm’ 操作)然后重新提交,文件就会消失。

要将文件返回到以前的状态:

    git checkout  

或将其返回到远程 HEAD 的状态:

    git checkout origin/master 

然后修改提交,您应该会发现该文件已从列表中消失(并没有从您的磁盘中删除!)

答7:

huntsbot.com全球7大洲远程工作机会,探索不一样的工作方式

git checkout HEAD~ path/to/file
git commit --amend

这是修改最后一次提交的最佳方式,即尚未推送的提交。这将重置一个文件中的更改,有效地从上次提交中删除该文件。

这也改变了文件。如何保留文件中的本地更改?

答8:

打造属于自己的副业,开启自由职业之旅,从huntsbot.com开始!

我会用例子向你解释。设 A、B、C 为 3 次连续提交。提交 B 包含一个不应提交的文件。

git log  # take A commit_id
git rebase -i "A_commit_ID" # do an interactive rebase
change commit to 'e' in rebase vim # means commit will be edited
git rm unwanted_file
git rebase --continue
git push --force-with-lease     

如果特定文件不在上一次或上一次提交中,这是最优雅的方式。我什至会说这是最优雅的方式。我喜欢交互式变基。

对于单个提交,将 noop 更改为 edit [A_commit_ID] 或 e [A_commit_ID]

@moaz-rashad 谢了!是的,这就是解决方案!

答9:

huntsbot.com汇聚了国内外优秀的初创产品创意,可按收入、分类等筛选,希望这些产品与实践经验能给您带来灵感。

以下将仅取消暂存您想要的文件,这是 OP 所要求的。

git reset HEAD^ /path/to/file

您将看到类似以下内容…

要提交的更改:(使用“git reset HEAD …”取消暂存)修改:/path/to/file 未暂存的更改提交:(使用“git add …”更新将提交的内容)(使用"git checkout – …" 丢弃工作目录中的更改)修改:/path/to/file

“要提交的更改”是提交之前文件的先前版本。如果文件从不存在,这看起来像是删除。如果您提交此更改,将会有一个修订版将更改还原到您的分支中的文件。

“Changes not staged for commit”是您提交的更改,以及文件的当前状态

此时,您可以对文件执行任何您喜欢的操作,例如重置为不同的版本。

当您准备好提交时:

git commit --amend -a

或(如果您正在进行一些其他不想提交的更改)

git commit add /path/to/file
git commit --amend

juzzlin 的回答很好,但是当您只想取消一个提交时,取消整个提交是过度的。如果您当前对该提交中的文件进行了您不想丢失的未暂存更改,则取消暂存整个提交可能会导致问题。

答10:

huntsbot.com – 程序员副业首选,一站式外包任务、远程工作、创意产品分享订阅平台。

你可以简单地试试。

git reset --soft HEAD~1

并创建一个新的提交。

但是,有一个很棒的软件“gitkraken”。这使得使用 git 变得容易。

请注意:在此之后,您将执行 git commit --amend 以在上次提交中更新文件删除;之后,您可以使用 git log -1 --stat 检查它确实已被删除

答11:

huntsbot.com聚合了超过10+全球外包任务平台的外包需求,寻找外包任务与机会变的简单与高效。

git rm --cached _which_added_file>
git commit -m "removed unwanted file from git"

仍然会给你留下本地文件。如果您也不希望该文件在本地,则可以跳过 --cached 选项。

如果所有工作都在您的本地分支上,您需要将文件保留在以后的提交中,并且就像拥有干净的历史记录一样,我认为更简单的方法可能是:

git rm --cached _which_added_file>
git commit --squash 
git add _which_added_file>
git commit -m "brand new file!"
git rebase --interactive ^

然后您可以轻松完成变基,而无需记住更复杂的命令或提交消息或键入太多内容。

这对我有用。我假设如果您想将文件重新添加到组合中,只需使用 git add -A 或 git add 。他们回来了。

原文链接:https://www.huntsbot.com/qa/WyJ6/remove-files-from-git-commit?lang=zh_CN&from=csdn

huntsbot.com全球7大洲远程工作机会,探索不一样的工作方式

到了这里,关于从 Git 提交中删除文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • git 配置,代码提交到仓库,不小心将node_modules上传,处理操作。.gitignore 删除已提交的文件

    我们经常会将将本地代码上传到线上仓库,例如uni项目,我们通常会忽略node_modules文件上传,其他同事从线上下载后,自行 npm install 安装,那如何进行忽略呢? 找到.gitignore文件,把你想要忽略上传的文件名称填进去即可。之后正常执行上传步骤。 而且在项目文件里面也没找到

    2024年02月13日
    浏览(55)
  • 如何使用Git提交文件

    git remote add origin 远程仓库URL git pull origin 分支名称 git checkout -b 分支名称 其他命令 常用命令 1.从远程仓库克隆项目到本地 git clone 项目地址 2.初始化本地仓库. git init # 创建本地仓库 3.本地仓库与远程仓库关联. git remote add 仓库名 仓库地址 # 仓库名自定义 例如:origin 4.查看仓库

    2024年02月05日
    浏览(33)
  • IDEA中git如何不提交指定文件

    这篇文章主要是记录JAVA IDEA在使用git时,如何不提交指定的文件,比如多人做一个项目时,不提交自己的yml文件到git上 在IDEA中,修改的文件回变成绿色,在使用commit时,会在对话框中,显示这些绿色文件,作为本次上传到git的文件 提交时的对话框是commit changes,默认情况下

    2024年02月11日
    浏览(30)
  • git 如何提交一个文件的一部分内容

    场景: 我正在开发代码开发了一半,现在突然要提交代码,但是需要提交的代码和我正在开发的代码 在一个文件中,我该如何提交 命令: git add -p (p是patch缩写) 第一步 :输入命令之后会呈现代码修改的部分 绿色的注释就是新增加内容 第二步: 按回车键查看命令解释 这

    2024年02月11日
    浏览(32)
  • Git 推送(提交)时如何忽略某个文件或目录?

    1、在工作目录下新建 .gitignore 文件 阿里云效 DevOps 实测! 2、配置忽略规则(支持正则) .gitignore 只能忽略那些原来没有被 track 的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。解决方法就是先把本地缓存删除(改变成未 track 状态),然后再提交。

    2024年02月11日
    浏览(37)
  • Git仓库的创建、常用命令、如何在 Git 中忽略文件提交以及 .gitignore 文件的作用和相关内容

    Git 仓库是用来存储版本控制信息的地方,为我们提供了快速便捷的代码管理方式。它可以包含文件、文件夹、历史记录、元数据等。在 Git 中,仓库通常分为两种:本地仓库和远程仓库。 如果你想分享你的代码库,并且希望团队中的其他成员可以跟踪你的进度和变化,你可以

    2024年02月02日
    浏览(33)
  • git 中如何删除 Untracked files 文件

    有时候,对于代码的改动,并不想提交,或者想直接拉取更新最新的远程仓库代码,但本地的代码已经做了很多的改动。解决办法: 一、Untracked files(未监控)的文件 Untracked files(未监控) 是你新增的文件,还没有被跟踪的文件。如何去掉它。 1.1、删除 Untracked files 1.2、连

    2024年02月04日
    浏览(32)
  • git提交记录全部删除

    目录 问题描述 解决方案 下载代码      分支查看 新建分支    迁移分支 删除老分支 恢复分支 结果 新复制的项目具有特比多的历史提交记录,我想给他清除,如下图。清除有一定好处,不清除过多历史也就导致包特别大,下载和提交等方面都会收到影响。 下载代码    

    2024年02月02日
    浏览(40)
  • git删除远程的提交记录

    环境: 1、本地代码仓y12345678,远程代码仓originy12345678 2、修改代码1条记录,add-commit-push到originy12345678 3、修改代码另1条记录,add-commit-push到originy12345678 问题1,如何删除远程分支上originy12345678的最新1条提交记录 1、在git本地分支y12345678上输入命令行:git reset --soft HEAD~1,表

    2024年02月09日
    浏览(25)
  • 删除误提交的 git commit

    某次的意外 commit 中误将密码写到代码中并且 push 到了 remote repo 里面, 本文将围绕这个场景讨论如何弥补. 在 Gitee 创建一个新的 Repo, clone 到本地 创建两个文件, commit 后 push 到 remote 作为初始提交 在 Gitee 检查提交成功: 分别修改两个文件, 模拟 A.txt 中误写入了敏感信息, B.txt 属

    2024年02月04日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包