回答

收藏

如何从当前 Git 工作树中删除本地(未跟踪)文件

技术问答 技术问答 628 人阅读 | 0 人回复 | 2023-09-11

如何从当前工作树中删除未跟踪的本地文件?
7 i1 O/ Z$ O% h7 v! E; H1 C1 J                                                               
* V- R+ O" Z6 t: D, M. k    解决方案:                                                                . v2 |. I& B; s
                                                                git-clean - 从工作树上删除未跟踪的文件概要git clean [-d] [-f] [-i] [-n] [-q] [-e ] [-x | -X] [--] …# }! K; Y2 ]- h0 }4 ~8 q) }7 X
描述通过从当前目录开始将不受版本控制的文件递归删除清理工作树。! Y' m& y6 \) j
通常, 只会被删除Git 未知文件,但如果-x如果指定了该选项,则将删除忽略的文件。例如,这对删除所有构建产品非常有用。8 c. E( E& V. S( Q0 P9 F3 C
如果...只有这些路径会受到任何可选参数的影响。
* O% B1 }  S9 S- Y使用步骤 1 -n选项显示将删除的内容:: `- @+ |0 g9 B( V6 w
# Print out the list of files and directories which will be removed (dry run)git clean -n -d清理步骤 -小心:此文件将被删除7 p% v1 K7 O) l3 [" O% e9 D
# Delete the files from the repositorygit clean -f删除目录,请操作git clean -f -d或git clean -fd
1 v0 @3 I" z" j) a' C. `0 S删除被忽略的文件,请操作git clean -f -X或git clean -fX1 }" M  _! E) E* Q+ i# R
删除忽略和不忽视的文件,请操作git clean -f -x或git clean -fx
请注意X后两个命令的大小写差异。% D# P2 |: k1 [; j) D8 H
如果clean.requireForce在您的配置中设置为true(默认值),需要指定-f否则,什么都不会发生。
, C+ E3 }- b7 w% f再次查看git-clean获取更多信息的文档。
$ K: X3 C, \, j1 |/ C- D选项-f,--force% n3 I# w6 g8 N3 j
如果 Git 配置变量 clean.requireForce 未设置为 false,除非给出或-f,否则 git clean 将拒绝运行。-n``-i
  {1 @4 w1 |' t0 k& n5 S( N, E6 F-x
1 X/ I% o& q! b) k从 不使用.gitignore(每个目录)和 阅读标准忽略规则$GIT_DIR/info/exclude,但仍然使用-e选项给出的忽略规则。这允许删除包括构建产品在内的所有未跟踪文件。这可以用于(可能与 git reset 结合使用)创建原始工作目录,测试清洁度。
) F7 D+ y6 c; y6 M+ F8 o: F# v7 @9 y-X! S* A0 [/ F+ _( E+ _7 u
仅删除 Git 忽略的文件。这可能对从零开始重建所有内容非常有用,但保留手动创建的文件。
, [; i7 {. d" @1 M2 E9 O. V) ]% J-n,--dry-run
. L# E) ]; |) }& B* I事实上,不要删除任何内容,只要显示要执行的操作。
7 ~& [7 H3 C, J3 |. y- j/ @-d, i" S$ ~* @; [4 s& Q0 Q
除了未跟踪的文件,未跟踪的目录也被删除。如果未跟踪的目录是不同的 Git 存储管理,默认情况下不会删除。-f如果您真的想删除此类目录,请使用两次选项。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则