如何从当前工作树中删除未跟踪的本地文件?
根据Git Documentation git clean
从工作树中删除未跟踪的文件
第1步是使用以下-n
选项显示将删除的内容:
# Print out the list of files which will be removed (dry run) git clean -n
清洁步骤 - 注意:这将删除文件:
# Delete the files from the repository git clean -f
要删除目录,请运行git clean -f -d
或git clean -fd
要删除被忽略的文件,请运行git clean -f -X
或git clean -fX
要删除忽略和未忽略的文件,请运行git clean -f -x
或git clean -fx
注意X
后两个命令的大小写差异.
如果clean.requireForce
在配置中设置为"true"(默认值),则需要指定-f
否则实际上不会发生任何事情.
再次查看git-clean
文档以获取更多信息.
-F
- 力
如果Git配置变量clean.requireForce未设置为false,则除非给定-f,-n或-i,否则git clean将拒绝运行.
-X
不要使用从.gitignore(每个目录)和$ GIT_DIR/info/exclude读取的标准忽略规则,但仍然使用-e选项给出的忽略规则.这允许删除所有未跟踪的文件,包括构建产品.这可以(可能与git reset一起使用)创建一个pristine工作目录来测试一个干净的构建.
-X
仅删除Git忽略的文件.这可能有助于从头开始重建所有内容,但保留手动创建的文件.
-n
--dry运行
不要删除任何东西,只显示将要做的事情.
-d
除了未跟踪的文件之外,删除未跟踪的目录.如果未跟踪的目录由不同的Git存储库管理,则默认情况下不会删除它.如果您确实要删除此类目录,请使用-f选项两次.
用于git clean -f -d
确保还删除了目录.
然后,您可以检查您的文件是否真的消失了git status
.
我很惊讶之前没有人提到过:
git clean -i
这代表交互式,您将快速了解将要删除的内容,为您提供包含/排除受影响文件的可能性.总的来说,仍然比--dry-run
真正的清洁前强制运行更快.
-d
如果你还想要处理空文件夹,你将不得不抛弃.最后,它有一个很好的别名:
git iclean
话虽这么说,额外的手持交互式命令可能会让有经验的用户感到厌倦.这些天我只是使用已经提到的git clean -fd
git-clean
- 从工作树中删除未跟踪的文件
如果未跟踪目录是它自己的git存储库(例如子模块),则需要使用-f
两次:
git clean -d -f -f
要删除所有未跟踪的文件,最简单的方法是先添加所有文件并重置repo,如下所示
git add --all git reset --hard HEAD
我喜欢git stash push -u
因为你可以用它们全部撤消它们git stash pop
.
编辑:我也发现了一种方法来显示未被跟踪的文件(例如git show stash@{0}^3
)/sf/ask/17360801/
EDIT2:git stash save
不赞成使用push
.谢谢@ script-wolf.
这就是我经常使用的:
git clean -fdx
对于一个非常大的项目,您可能希望运行它几次.
你正在寻找git-clean.它用于从工作树中删除未跟踪的文件.
如果需要从特定子目录中删除未跟踪的文件,
git clean -f {dir_path}
并结合使用方法删除未跟踪的目录/文件和忽略的文件.
git clean -fxd {dir_path}
在此之后,您将只修改文件git status
.
git clean -fd
删除目录
git clean -fX
删除被忽略的文件
git clean -fx
删除被忽略和未被忽略的文件
可以将以上所有选项组合使用
git clean -fdXx
检查git手册以获得更多帮助
删除此repo +子模块中的所有额外文件夹和文件
这使您处于与新克隆相同的状态.
git clean -ffdx
删除此仓库中的所有额外文件夹和文件,但不删除其子模块
git clean -fdx
仅删除额外的文件夹但不删除文件(例如构建文件夹)
git clean -fd
删除额外的文件夹+忽略的文件(但不删除任何新添加的文件)
如果文件未被忽略且尚未签入,那么它将保留.注意大写字母X.
git clean -fdX
新的互动模式
git clean
好的,在命令行中可以轻松删除不需要的未跟踪文件和文件夹git
,只需这样做:
git clean -fd
在执行之前仔细检查,因为它将删除文件和文件夹而不创建任何历史记录...
同样在这种情况下,-f
代表力并-d
代表目录......
因此,如果您只想删除文件,则只能使用-f
:
git clean -f
如果要删除(目录)和文件,则只能删除未跟踪的目录和文件,如下所示:
git clean -fd
此外,您可以使用-x
flag来包含git忽略的文件.如果要删除所有内容,这将非常有用.
并添加-i
标志,使git要求您在移动中逐个删除文件的权限.
如果您不确定并想先检查一下,请添加-n
标记.
-q
如果您不希望在成功删除后看到任何报告,请使用.
我还创建了下面的图像,使其更具记忆性,特别是我看到很多人-f
有时会混淆清理文件夹或以某种方式混合它!
更好的方法是使用:git clean
git clean -d -x -f
这将删除未跟踪的文件,包括(-d)
被忽略的目录和文件git (-x)
.
此外,将-f
参数替换-n
为执行dry-run
或-i
用于交互模式,它将告诉您将删除的内容.
用户互动方式:
git clean -i -fd Remove .classpath [y/N]? N Remove .gitignore [y/N]? N Remove .project [y/N]? N Remove .settings/ [y/N]? N Remove src/com/arsdumpgenerator/inspector/ [y/N]? y Remove src/com/arsdumpgenerator/manifest/ [y/N]? y Remove src/com/arsdumpgenerator/s3/ [y/N]? y Remove tst/com/arsdumpgenerator/manifest/ [y/N]? y Remove tst/com/arsdumpgenerator/s3/ [y/N]? y
-i for interactive
-f for force
-d for directory
-x for ignored files(如果需要,添加)
注意: 添加-n或--dry-run以检查它将执行的操作.
git clean -f -d -x $(git rev-parse --show-cdup)
将clean应用于根目录,无论您在存储库目录树中何处调用它.我一直使用它,因为它不会强迫你离开你现在工作的文件夹,并允许从你所在的地方清理和提交.
确保标志-f
,-d
,-x
满足您的需求:
-d Remove untracked directories in addition to untracked files. If an untracked directory is managed by a different Git repository, it is not removed by default. Use -f option twice if you really want to remove such a directory. -f, --force If the Git configuration variable clean.requireForce is not set to false, git clean will refuse to delete files or directories unless given -f, -n or -i. Git will refuse to delete directories with .git sub directory or file unless a second -f is given. This affects also git submodules where the storage area of the removed submodule under .git/modules/ is not removed until -f is given twice. -x Don't use the standard ignore rules read from .gitignore (per directory) and $GIT_DIR/info/exclude, but do still use the ignore rules given with -e options. This allows removing all untracked files, including build products. This can be used (possibly in conjunction with git reset) to create a pristine working directory to test a clean build.
还有其他标志,只需检查git clean --help
.
对我来说只有工作:
git clean -ffdx
在所有其他情况下,我收到一些子目录的消息"跳过目录".
我刚刚发明并尝试过这种情况的生活方式(完美无缺):
git add . git reset --hard HEAD
谨防!在执行此操作之前,请务必提交任何所需的更改(即使在非未跟踪的文件中).
如果您只想删除"git status"未列出的文件
git stash save -u git stash drop "stash@{0}"
我更喜欢这个'git clean'因为'git clean'会删除被git忽略的文件,所以你的下一个版本将不得不重建所有内容,你也可能会失去你的IDE设置.
要知道在实际删除之前将删除的内容:
git clean -d -n
它将输出如下内容:
将删除sample.txt
要删除上一个命令的输出中列出的所有内容:
git clean -d -f
它将输出如下内容:
删除sample.txt
要删除未跟踪的文件,首先应使用命令查看将受清理影响的文件
git clean -fdn
这将显示将要删除的文件列表.现在要实际删除这些文件使用此命令:
git clean -fd
始终 -n
在运行实际命令之前使用,因为它将显示将删除哪些文件.
git clean -n -d git clean -f -d
默认情况下,git clean
仅删除未被忽略的未跟踪文件.任何与.gitignore中的模式匹配的文件或其他忽略文件都不会被删除.如果您也想删除这些文件,可以-x
在clean命令中添加.
git clean -f -d -x
-i
clean命令还提供了交互模式
git clean -x -i另外
如果您不是100%确定删除未提交的作品是安全的,则可以使用存储
git stash --all
它还将清除您的目录,但允许您使用带有apply或pop的存储在任何时间点检索文件.然后在稍后您可以使用以下方法清除您的存储:
git stash drop // or clean
git clean -f to remove untracked files from working directory.
我在博客git-intro-basic-commands中介绍了一些基础知识
用于从git docs中删除未跟踪文件的 uggested命令是git clean
git clean - 从工作树中删除未跟踪的文件
建议的方法:使用的 交互模式,git clean -i
我们可以控制它.让我们看看剩余的可用选项
可用选项:
git clean -d -f -i -n -q -e -x -X (can use either)
说明:
1. -d
除了未跟踪的文件之外,删除未跟踪的目录.如果未跟踪的目录由不同的Git存储库管理,则默认情况下不会删除它.如果您确实要删除此类目录,请使用-f选项两次.
2. -f, - force
如果Git配置变量clean.requireForce未设置为false,则除非给定-f,-n或-i,否则git clean将拒绝运行.
3.-i, - 相互作用
显示将要执行的操作并以交互方式清理文件.有关详细信息,请参阅"交互模式"
4. -n, - 干跑
不要删除任何东西,只显示将要做的事情.
5. -q, - quiet
保持安静,仅报告错误,但不报告成功删除的文件.
6. -e, - exclude =
除了在.gitignore(每个目录)和$ GIT_DIR/info/exclude中找到的那些之外,还要考虑这些模式在有效的忽略规则集中.
7. -x
不要使用从.gitignore(每个目录)和$ GIT_DIR/info/exclude读取的标准忽略规则,但仍然使用-e选项给出的忽略规则.这允许删除所有未跟踪的文件,包括构建产品.这可以(可能与git reset一起使用)创建一个pristine工作目录来测试一个干净的构建.
8. -X
仅删除Git忽略的文件.这可能有助于从头开始重建所有内容,但保留手动创建的文件.
普通git clean
命令不会删除未跟踪的文件git version 2.9.0.windows.1
.
$ git clean -fdx # doesn't remove untracked files $ git clean -fdx * # Append star then it works!
我们可以使用下面的git注释轻松地从当前git工作树中删除本地未跟踪文件.
git reset [--soft | --mixed [-N] | --hard | --merge | --keep] [-q] []
例:
git reset --hard HEAD
链接:
https://git-scm.com/docs/git-reset
如何使用'git reset --hard HEAD'恢复到之前的提交?
将本地存储库分支重置为远程存储库HEAD
https://jwiegley.github.io/git-from-the-bottom-up/3-Reset/4-doing-a-hard-reset.html