我可以忽略本地文件而不污染其他人的全局git配置吗?我的git状态中有未跟踪的文件是垃圾邮件,但我不想为我在本地分支中的每一个未跟踪的小文件提交git配置更改。


当前回答

更新:考虑使用git更新索引--跳过工作树[<file>…],谢谢@danShumway!参见Borealid对两个选项差异的解释。


旧答案:

如果您需要忽略跟踪文件的本地更改(我们对配置文件进行了本地修改),请使用git更新索引--假设未更改[<file>…]。

其他回答

在项目存储库中,接受的答案对我来说很有用。git在排除文件中添加了以下内容:

wp内容/插件

wp内容/上传

对于希望忽略子模块中本地文件的任何人:

使用与.gitignore文件相同的格式编辑父repo/.git/modules/my子模块/info/exclude。

假设不变和跳过工作树都不是忽略本地文件的正确方法。。。请检查此答案和git更新索引文档中的注释。由于任何原因不断频繁更改(和/或从一个克隆更改为另一个克隆)的文件,且不应提交其更改,则不应首先跟踪这些文件。

但是,有两种适当的方法可以在本地忽略文件(这两种方法都可以处理未跟踪的文件)。要么将文件名放在.git/info/exclude文件中,该文件是.gitignore的本地替代文件,但特定于当前克隆。或者使用global.gitignore(它应该只正确用于常见的辅助文件,例如pyz、pycache等),该文件将在机器中的任何git repo中被忽略。

为了实现上述自动化(添加到exclude或global.gitignore),可以使用以下命令(添加到bash配置文件):

每个克隆本地排除(请注意,您应该位于由于使用相对路径而调用命令时的存储库),将##FILE-NAME##更改为.git/info/excludeGlobal.gitignore,首先在这里设置Global.gitignor将##FILE-NAME##更改为~/.gitignore

Linux系统

alias git-ignore='echo $1 >> ##FILE-NAME##'
alias git-show-ignored='cat ##FILE-NAME##'
git-unignore(){
  GITFILETOUNIGNORE=${1//\//\\\/}
  sed -i "/$GITFILETOUNIGNORE/d" ##FILE-NAME##
  unset GITFILETOUNIGNORE
}

MacOS(您需要.bak进行sed就地修改(即,您被迫向就地sed添加文件扩展名。即,在替换某些内容之前进行备份),因此要删除我添加的.bak文件rm filename.bak)

alias git-ignore='echo $1 >> ##FILE-NAME##'
alias git-show-ignored='cat ##FILE-NAME##'
git-unignore(){
  GITFILETOUNIGNORE=${1//\//\\\/}
  sed -i.bak "/$GITFILETOUNIGNORE/d" ##FILE-NAME##
  rm ##FILE-NAME##.bak
  unset GITFILETOUNIGNORE
}

然后您可以执行以下操作:

git忽略example_file.txtgit unignore示例文件.txt

您可以简单地将.gitignore文件添加到您的主目录中,即$home/.gitignore/~/.giti忽略。然后告诉git将该文件与命令一起使用:

git config --global core.excludesfile ~/.gitignore

这是一个普通的.gitignore文件,git在决定忽略什么时会引用它。因为它在您的主目录中,所以它只适用于您,不会污染任何project.gitignore文件。

多年来,我一直在使用这种方法,取得了很好的效果。

从相关Git文档中:

特定于特定存储库但不需要与其他相关存储库共享的模式(例如,位于存储库内部但特定于一个用户工作流的辅助文件)应进入$GIT_DIR/info/exclude文件。

.git/info/exclude文件的格式与任何.gitignore文件的格式相同。另一个选项是将core.excludesFile设置为包含全局模式的文件的名称。

注意,如果您已经有未标记的更改,则必须在编辑忽略模式后运行以下命令:

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

关于$GIT_DIR的说明:这是整个GIT手册中使用的一种符号,只是为了指示GIT存储库的路径。如果设置了环境变量,那么它将覆盖您所在的任何存储库的位置,这可能不是您想要的。


编辑:另一种方法是使用:

git update-index --skip-worktree <file-list>

反转方式:

git update-index --no-skip-worktree <file-list>