Git似乎忽略了我的.gitignore文件-.gitignorefile是否已损坏?Git希望使用哪种文件格式、区域设置或文化?

我的.gitignore:

# This is a comment
debug.log
nbproject/

git状态的输出:

# On branch master
# Your branch is ahead of 'origin/master' by 1 commit.
#
# Untracked files:
#   (use "git add <file>..." to include in what will be committed)
#
#       debug.log
#       nbproject/
nothing added to commit but untracked files present (use "git add" to track)

我希望debug.log和nbproject/不出现在未跟踪的文件列表中。

我应该从哪里开始解决这个问题?


当前回答

我在Windows中的PowerShell中使用echo“…”>.gitignore创建了.gitignor,因为它不允许我在Windows资源管理器中创建它。

在我的案例中,问题是创建的文件的编码,在我将其更改为ANSI后,问题得到了解决。

其他回答

特别适用于Windows用户:如果您有未跟踪的文件,并且无法清除/删除缓存的文件。尝试打开PowerShell并将.gitignore文件转换为UTF-8编码:

$Myfile = Get-Content .\.gitignore`
$Myfile | Out-File -Encoding "UTF8" .gitignore

您只需要这样做一次,就可以对该目录的.gitignore文件进行编码,并且由于该文件随后被正确编码,因此无论您将来何时编辑该文件,它都会正常工作。我认为这是由于GitHub无法读取.gitignore文件的非UTF-8编码而出现的问题。据我所知,Windows尚未解决此问题。这没什么大不了的,只是当它不工作时调试起来很痛苦。

还可以查看放置.gitignore的目录。

它应该位于项目的根目录中:

./myproject/.gitignore

不在

./myproject/.git/.gitignore

在不向项目添加另一个提交的情况下,一行代码就足以让.gitignore按预期工作:

git rm -r --cached debug.log nbproject

这将从存储库中删除它们,但仍保留它们。简单地说,它会删除与它们相关的任何更改历史记录,并且不会在将来的任何提交中跟踪它们的更改。你可以在这里找到更好的解释。

对我来说,这又是一个问题。我的.gitignore文件被设置为忽略除我告诉它不要忽略的内容之外的所有内容。像这样:

/*
!/content/

现在这显然意味着我也在告诉Git忽略.gitignore文件本身。只要我没有跟踪.gitignore文件,这就不是问题。但在某个时刻,我提交了.gitignore文件本身。这导致.gitignore文件被正确忽略。

因此,再增加一行就解决了这个问题:

/*
!/content/
!.gitignore

这里的所有答案实际上都是变通方法。在运行gitinit之前,需要创建.gitignore文件。否则git永远不会知道你需要忽略这些文件,因为它们已经被跟踪了。

echo .idea/ >> .gitignore
git init

如果您每天都在开发,我建议您将习惯性忽略的文件添加到~/.gitignore_global文件中。这样,git就可以知道您(意思是“您的用户”,因为它是您的主目录中的文件)通常忽略的文件。