关于git rm --cached和.gitignore

在删除git项目中的文件时,常用的一个命令是

git rm <yourfile>

其效果为同时删除在本地和暂存区的<yourfile>文件。有时我们希望保留本地文件,但使该文件停止被git追踪,那么我们需要使用

git rm --cached <yourfile>

这样当别人从你的仓库中pull时,他们是无法看到<yourfile>的。

比如我在本地创建一个叫做git_test的目录:

mkdir git_test && cd git_test

再将它初始化为git项目并在其中创建一个名为file1.txt和一个file2.txt的文件:

git init

touch file1.txt file2.txt

再将修改提交到远端的git仓库中 :

git add .

git commit -m "Add file1.txt, file2.txt"

git remote add <reponame> <repoaddress>

git push -u <reponame> <yourbranch>

其中的<reponame>,<repoaddress>,<yourbranch>分别指代远程仓库的名字(可自定义,习惯上为origin),远程仓库的地址(https/ssh)和你希望push的分支名。在我的Github仓库中便可以看到我的更新记录:

成功git push后可以看到file1.txt和file2.txt都被更新到了远程仓库

然后用git rm --cached从暂存区中移除 file1.txt:

git rm --cached file1.txt

在我的git status 中,可以看到file1.txt变为了Untracked file

file1.txt显示为Untracked file

而在我的本地文件目录中,file1.txt仍然存在:

这时候编辑file1.txt,再在git status 中查看,会发现对file1.txt的编辑是not staged for commit的。

但是当使用git add .时,查看status后发现对file1.txt的更改又重新成为了To be commited。

为了使git add . 忽略这一改动,则需要在.gitignore中添加file1.txt的路径。

清空暂存区:

git reset

而由于git add . 使file1.txt重新被git追踪,故需要再次在暂存区中将其删除。

在git项目的根目录下创建.gitignore,并在其中写入file1.txt的地址:

touch .gitignore

nano .gitignore

再写入file1.txt (前提是在.gitignore同一路径下,否则需要写相对路径或者绝对路径)。将删除后的改动push到远程仓库,可以看见远程仓库中的file1.txt也相应地消失了:

这时再编辑file1.txt,会发现在git status 中也不出现相关的信息了(对比之前只是列为Untracked file,但是仍然会显示):

git add . 中也没有任何file1.txt的记录。但是请注意,如果指名道姓

git add file1.txt

会有如下提示:

可以使用-f(--force)参数使其强制被add到暂存区,这时它又会重新被git追踪:

这时如果希望再次将其从暂存区中删除,则需要重新

git rm --cached file1.txt

还需注意的一点是,.gitignore文件作用的对象只能是Untracked File!

如果在.gitignore中写入file2.txt(Tracked File),那么将无事发生,对file2.txt的修改在git status中仍然可见,也会在git add .中被添加到暂存区。

 相关仓库见https://github.com/ylctql/git_test.git 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值