在删除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 。