我在我的存储库中有一些文件应该被忽略,我将它们添加到.gitignore,但是,当然,它们不会从我的存储库中删除。

所以我的问题是,是否有一个神奇的命令或脚本使用过滤器分支,可以重写我的历史,并轻松删除所有这些文件?或者只是一个创建提交并删除它们的命令?


当前回答

当你将。gitignore模式添加到。gitignore后,git会忽略匹配的文件。

但是存储库中已经存在的文件仍然存在。

使用git rm files_ignored;Git提交-m 'rm no use files'删除被忽略的文件。

其他回答

在linux中,你可以使用这个命令:

例如,我想删除*.py~,所以我的命令应该是==>

找到。name "*.py~" -exec rm -f {} \;

不管操作系统是什么,一个更简单的方法是

git rm -r --cached .
git add .
git commit -m "Drop files from .gitignore"

你基本上删除并重新添加所有文件,但是git add会忽略.gitignore中的文件。

使用——cached选项将文件保存在文件系统中,这样就不会从磁盘中删除文件。

注意: 有些人在评论中指出,你将失去所有文件的历史记录。我在MacOS上用git 2.27.0进行了测试,结果不是这样。如果你想检查发生了什么,在你提交之前检查你的git diff HEAD~1。

Git rm——cached -r。 以递归方式删除所有缓存

Git添加。 添加所有未包含在.gitignore中的文件

你将不得不提交一些在文件系统上没有真正删除的已删除文件

使用一个命令就可以了 Git rm——cached -r。&& git添加。

通过使用sed操作.gitignore语句的输出,我做了一个非常简单的解决方案:

Cat .gitignore | sed '/^#。* / d ' | sed ' / ^ \ s *美元/ d ' | sed ' s / ^ / git rm - r / | bash

解释:

打印.gitignore文件 从打印中删除所有注释 删除所有空行 在行首添加'git rm -r ' 执行每一行。

当你将。gitignore模式添加到。gitignore后,git会忽略匹配的文件。

但是存储库中已经存在的文件仍然存在。

使用git rm files_ignored;Git提交-m 'rm no use files'删除被忽略的文件。