我在.gitignore中添加了以下一行:

sites/default/settings.php

但是当我输入git状态时,它显示文件为unstaging文件。

有什么问题吗?所有其他模式都很好。


当前回答

请使用此命令

git rm -rf --cached .
git add .

有时.gitignore文件即使是正确的也不能工作。Git忽略文件的原因是它们没有被添加到存储库中。如果您之前添加了一个想要忽略的文件,Git将跟踪它,并且将跳过任何跳过的匹配规则。Git这样做是因为该文件已经是存储库的一部分。

其他回答

以防将来有人遇到和我一样的问题

如果你使用

*
!/**/
!*.*

移除没有扩展名的二进制文件的技巧,确保所有其他gitignore行都在下面。Git会从顶部读取。gitignore,所以即使我有'test. Git '。“Go”在我的gitignore中,它是文件中的第一个,然后变成了“不可忽视”

!*.*

.gitignore将只忽略你还没有添加到存储库的文件。

如果你做了git add .,文件被添加到索引中,.gitignore不会帮助你。你需要执行git rm sites/default/settings.php来删除它,然后它就会被忽略。

我在VS Code终端上尝试了上面的大多数命令,我得到了如下错误:

致命:pathspec '[dir]/[file]'没有匹配任何文件

我在GitHub Desktop上打开了这个项目,然后忽略了它,它工作了。

一个棘手的问题是,如果你执行类似echo node_modules >> .gitignore这样的操作,它将不起作用。windows终端在UCS-2 LE BOM中保存文件,git似乎不接受这一点。

您可以使用记事本打开文件,并使用UTF-8编码保存它

现在起作用了。

我认为他们需要修复这个,因为echo "filetoignore" >> .gitignore实际上似乎是一个方便的事情要做

有一些实例,例如应用程序配置文件,我想在git中跟踪(因此.gitignore将不起作用),但我需要更改本地设置。我不希望git管理这些文件或将其显示为修改。要做到这一点,我使用skip-worktree:

git update-index --skip-worktree path/to/file

您可以通过列出文件并检查以S开头的行是否被跳过来确认文件被跳过

git ls-files -v | grep ^S

如果将来你想让git再次在本地管理文件,只需运行:

 git update-index --no-skip-worktree path/to/file

上面的麦斯卡利托给出了一个很好的答案,引导我走上了正确的道路,但是

Git update-index——assume-unchanged file/to/ignore.php

与git有一个合同,其中:用户承诺不更改文件,并允许git假设工作树文件与索引中记录的文件匹配。

然而,我改变了文件的内容,所以在我的例子中——skip-worktree是更好的选择。

Toshiharu Nishina的网站提供了一个关于skip-worktree和假设不变的很好的解释:忽略已经在Git本地管理的文件