我把这个添加到。gitignore文件

.idea/*

但无论如何,现状是:

#       modified:   .gitignore
#       modified:   .idea/.generators
#       modified:   .idea/dovezu.iml
#       modified:   .idea/misc.xml
#       modified:   .idea/workspace.xml

我做错了什么? 我甚至在全局变量~/.gitignore_global中添加了.idea/* 但是git的状态告诉我:

#       modified:   .gitignore
#       modified:   .idea/.generators
#       modified:   .idea/dovezu.iml
#       modified:   .idea/misc.xml
#       modified:   .idea/workspace.xml

当前回答

如果你用类似echo node_modules >> .gitignore这样的东西来保存它,也会发生这种情况

windows终端以UCS-2 LE BOM编码保存文件,git似乎不接受这一点。

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

现在起作用了。

我认为他们应该修复这个问题,因为做echo "filetoignore" >> .gitignore实际上似乎非常方便。

其他回答

这里和其他地方提供的解决方案对我不起作用,所以我将为将来的读者补充讨论。我承认我还没有完全理解这个过程,但我终于解决了我的(类似的)问题,想要分享。

当我在Windows 10的IntelliJ IDEA中使用git时,我无意中缓存了一些包含数百个文件的文档目录,在将它们添加到.gitignore后(可能会移动它们一点),我无法将它们从默认更改列表中删除。

我首先提交了我所做的实际更改,然后着手解决这个问题——花了我太长时间。 我尝试了git rm -r——cached。但是总是会得到路径规范错误,带有不同的路径规范变体以及-f和-r标志。

git状态仍然会显示文件名,所以我尝试使用git rm -cached中的一些文件,但没有运气。 存储和解存储更改似乎是有效的,但它们在一段时间后再次排队(我对确切的时间框架有点不清楚)。 我最终删除了这些条目,以便更好地使用

git reset

我认为这只是一个好主意,当您没有真正想要提交的暂存/缓存更改时。

对于那些可能仍然在搜索这个问题的人,只看这一页。

这将帮助您删除缓存的索引文件,然后只添加您需要的索引文件,包括对.gitignore文件的更改。

1. git rm -r --cached .
2. git add .
3. git commit -m 'Removing ignored files'

这里有更多的信息。

此命令将从索引中删除所有缓存文件。 该命令将添加除gitignore中提到的文件之外的所有文件。 这个命令将再次提交文件,并删除你想让git忽略的文件,但将它们保存在本地目录中。

Git添加。 Git状态//查看正在修改的文件 // git reset HEAD—替换为你想忽略的文件 git重置HEAD .idea/ <——那些想要在提交前排除.idea的人 // git检查状态和想法文件将消失,你已经准备好了! Git commit -m " git推

如果你用类似echo node_modules >> .gitignore这样的东西来保存它,也会发生这种情况

windows终端以UCS-2 LE BOM编码保存文件,git似乎不接受这一点。

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

现在起作用了。

我认为他们应该修复这个问题,因为做echo "filetoignore" >> .gitignore实际上似乎非常方便。

简单添加git rm -r——cached <folder_name/file_name>

有时,在文件的commit命令之后更新.gitignore文件。文件被缓存在内存中。要删除缓存的文件,使用上面的命令。