git clean的作用是删除工作目录中尚未添加到git版本控制的文件或目录。
未添加到版本控制,且不在.gitignore中的,都是Untracked的状态。
有时候我们在项目中添加了些文件、目录测试了一把,测试完成后想把它们删了。
有时候则是执行回滚后,有些文件或目录回滚到了Untracked状态,我们需要把它们删掉。
这时候就可以使用git clean。
git clean的用法:
usage: git clean [-d] [-f] [-n] [-q] [-x | -X] [--] <paths>...
-q, --quiet be quiet(静默删除,只会告诉你出错信息。如果是成功删除了文件或目录则保持沉默)
-n, --dry-run dry run(告诉你会被删除的文件或目录有哪些,删除文件毕竟是一件严肃的事,在执行该命令前请务必加上该参数先确定下)
-f, --force force(强制删除,clean.requireForce默认的值是true。这种情况下只有加上该参数才能删除)
-d remove whole directories(删除的范围是整个目录)
-x remove ignored files, too(即使是被添加进gitignore的文件或目录也删掉。这里有坑,下面说~)
-X remove only ignored files(只删除被添加进gitignore的文件或目录)
所以,在执行该命令前,务必先加上-n以检查一遍。否则删除后要找回来也是挺麻烦的事~
有坑:
不加上x参数,是不会删除被ignore的文件或目录的。但是~!!
如果你在.gitignore文件中对目录的描述是dir/*
那么很抱歉,这个目录及里面的文件也会被清除掉。即使该目录的确是被git所忽略的。
所以,在.gitignore中对目录的描述最好是
dir1/
dir2
最后吐槽网上很多关于git clean的介绍(中文的)中,对-f参数的描述是file。但其实是force~
- 本文固定链接: http://zoufeng.net/2016/08/05/git-clean/
- 转载请注明: foam 2016年08月05日于 foam 发表