我在一个变更集中有一堆文件,但我想特别忽略一个修改过的文件。在git状态后看起来如下:

# modified:   main/dontcheckmein.txt
# deleted:    main/plzcheckmein.c
# deleted:    main/plzcheckmein2.c
...

有没有一种方法可以让我添加git,但忽略我不想触摸的一个文本文件?类似于:

git add -u -except main/dontcheckmein.txt

当前回答

git add .
git reset main/dontcheckmein.txt

其他回答

你可以试试这个:git add*&&git reset main/dontcheckmein.txt

试试看:

git checkout -- main/dontcheckmein.txt

如果每次有三个有效的解决方案不涉及.gitignore时都要忽略特定的文件。

将要忽略的文件添加到.git/info/exclude。它的工作方式与.gitignore类似,只是配置特定于您的计算机。使用预提交git钩子重置您想要的文件。例如:$echo'git重置--src/main/resources/log4j.财产'>>.git/hooks/pre-commit$chmod+x.git/hooks/预提交预提交钩子就在提交之前运行。因此,您的文件可以在每次提交前自动重置。$git状态在分支机构CHANGE-137-notifications-support。。。未暂存用于提交的更改:修改:Dockerfile修改:src/main/resources/log4j.properties$git添加。$git状态在分支机构CHANGE-137-notifications-support。。。要提交的更改:修改:Dockerfile修改:src/main/resources/log4j.properties$gitcommit-m“微不足道的变化”重置后未分级的更改:M src/main/resources/log4j.属性[CHANGE-137-notifications-support 97cfb3f]微不足道的变化1个文件已更改,3个插入(+)第三种方法是更新特定文件的索引。$git update-index--假定更改了src/main/resources/log4j.properties

git add -u
git reset -- main/dontcheckmein.txt

注意:Git随后为此添加了特殊语法,其他答案对此进行了解释。

虽然本·杰克逊是正确的,但我想我也会补充一下我是如何使用这个解决方案的。下面是我使用的一个非常简单的脚本(我称之为gitadd)来添加所有更改,除了我在一个名为.gittrackignore的文件中列出的少数更改(非常类似于.gitignore的工作方式)。

#!/bin/bash
set -e

git add -A
git reset `cat .gittrackignore`

这就是我当前的.gittrackignore的样子。

project.properties

我正在开发一个Android项目,在部署时我从命令行编译。这个项目依赖于SherlockActionBar,因此需要在project.properties中引用它,但这会影响编译,所以现在我只需键入gitadd并将所有更改添加到git中,而不必每次都取消添加project.properties。