我有一个已经初始化的Git存储库,我添加了一个.gitignore文件。我如何刷新文件索引,以便忽略我想要忽略的文件?


当前回答

我不太清楚“回答”命令是什么意思,所以我运行了它,这让我非常沮丧。它递归地从git repo中删除每个文件。

Stackoverflow救援。。。如何还原“git rm-r”?

git reset HEAD

做到了这一点,因为我有未提交的本地文件,我不想覆盖这些文件。

其他回答

我不太清楚“回答”命令是什么意思,所以我运行了它,这让我非常沮丧。它递归地从git repo中删除每个文件。

Stackoverflow救援。。。如何还原“git rm-r”?

git reset HEAD

做到了这一点,因为我有未提交的本地文件,我不想覆盖这些文件。

如果您试图忽略对存储库中已跟踪的文件所做的更改(例如,您需要为本地环境更改的dev.properties文件,但您永远不想签入这些更改),那么您要做的是:

git update-index --assume-unchanged <file>

如果你想再次开始跟踪更改

git update-index --no-assume-unchanged <file>

参见git更新索引(1)手册页。

如果您需要在git重置后继续使用,请查看更新索引的跳过工作树和无跳过工作树选项(通过)


更新:由于人们一直在问,这里有一个方便的(并在下面评论后进行了更新)别名,用于查看本地工作区中哪些文件当前被“忽略”(--假设未更改)

$ git config --global alias.ignored = !git ls-files -v | grep "^[[:lower:]]"

对于像我这样的迟钝的人,还有一个建议:)将.gitignore文件放到存储库根目录中,而不是放到.git文件夹中。干杯

正如dav_i所说,为了将文件保存在repo中,并在不创建额外提交的情况下将其从更改中删除,您可以使用:

git update-index --assume-unchanged filename

我发现了一个奇怪的问题。gitignore。一切都很到位,看起来很正确。我的.gitignore被“忽略”的唯一原因是,行结尾是Mac格式(\r)。因此,在保存了具有正确行结尾的文件(在vi中使用:set ff=unix)之后,一切都变得非常迷人!