git移除上一次的commit中误添加的文件

时间:2023-03-09 20:25:01
git移除上一次的commit中误添加的文件

在使用git进行版本管理时,往往会出现一些误操作,比如将一些不加上传的文件放到了暂存区,即上传到了上一次commit中

比如:

commit c134ab90ca7c4daf8bfa22e3ad706150abbd9bbc
Author: lin <@qq.com>
Date: Mon Jan :: + 添加了不想放入暂存区的文件 Change-Id: I911c17175d0637de21824d34bc2b7bf8055e9d6c package-lock.json | ++++++++++++++++++++++++++++++++++++++++++++++++++++
file changed, insertions(+)

那么如何才能将他移出暂存区呢

解决方案一:

.
git rm --cached package-lock.json ----- result ------- rm 'package-lock.json' .
git status ----- result ------- On branch demo
Changes to be committed:
(use "git reset HEAD <file>..." to unstage) deleted: package-lock.json Untracked files:
(use "git add <file>..." to include in what will be committed) package-lock.json .
git commit --amend --allow-empty
查看log
.
git log --stat ------- result --------- commit ce6be4ee3179030606bcc3506d5ea4f14ad63fe1
Author: lin <@qq.com>
Date: Mon Jan :: + 添加了不想放入暂存区的文件 Change-Id: I911c17175d0637de21824d34bc2b7bf8055e9d6c
结论

上一次的commit中已经没有了误添加的文件,且Change-Id与修改前相同,只是一次 amend

解决方案二

.
git reset --mixed HEAD~1 -------- result ---------- On branch demo
Untracked files:
(use "git add <file>..." to include in what will be committed) package-lock.json . git log ---------resut ---------
上一次的commit已经被删除了