git clean

git clean的作用是删除工作目录中尚未添加到git版本控制的文件或目录。

未添加到版本控制,且不在.gitignore中的,都是Untracked的状态。

有时候我们在项目中添加了些文件、目录测试了一把,测试完成后想把它们删了。

有时候则是执行回滚后,有些文件或目录回滚到了Untracked状态,我们需要把它们删掉。

这时候就可以使用git clean。

git clean的用法:

usage: git clean [-d] [-f] [-n] [-q] [-x | -X] [--] ...
 
    -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 发表

你可能感兴趣的:(git clean)