我把这个添加到。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

当前回答

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

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

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

这里有更多的信息。

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

其他回答

索引更新——skip-worktree

忽略配置文件的特定git选项是:

$ git update-index --skip-worktree <filepath>

注意,不需要在.gitignore中添加任何东西。

要取消此设置,例如当配置文件的通用结构发生更改时:

$ git update-index --no-skip-worktree <filepath>

——skip-worktree用于指示git永远不要将文件更改索引到特定的文件。这可能是因为开发人员通常需要在本地更改文件以测试项目。例如,如果主存储库上游托管了一个可用于生产的配置文件,那么应该防止对该文件的意外提交更改。

而——assume-unchanged则假设开发人员永远不应该更改该文件。这个标志仅仅是为了提高git的性能,不改变像软件开发工具包(SDK)组件这样的文件夹。

您的.gitignore正在工作,但它仍然跟踪文件,因为它们已经在索引中。

要停止这个,你必须这样做:git rm -r——cached .idea/

当你提交时。idea/目录将从你的git存储库中删除,接下来的提交将忽略。idea/目录。

PS:你可以用.idea/代替.idea/*来忽略一个目录。您可以在.gitignore手册页上找到关于模式的更多信息。


来自git-rm手册页的有用引用

--cached
    Use this option to unstage and remove paths only from the index. 
    Working tree files, whether modified or not, will be left alone.

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

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

我插一句。在我的例子中,子目录中有一个git repo,因为我从其他人那里解压缩了一个zip文件,然后递归地将他们解压缩zip中的所有内容复制到我的repo中,而没有检查我正在复制什么。

一旦我吹走了我现有的回购中的.git目录,一切都很好。

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

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

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

这里有更多的信息。

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