我在一个变更集中有一堆文件,但我想特别忽略一个修改过的文件。在git状态后看起来如下:
# modified: main/dontcheckmein.txt
# deleted: main/plzcheckmein.c
# deleted: main/plzcheckmein2.c
...
有没有一种方法可以让我添加git,但忽略我不想触摸的一个文本文件?类似于:
git add -u -except main/dontcheckmein.txt
我在一个变更集中有一堆文件,但我想特别忽略一个修改过的文件。在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
其他回答
对于问题中的特定情况,最简单的方法是添加所有扩展名为.c的文件,而忽略其他所有内容:
git add *.c
从git scm(或/和man git add):
git-add<pathspec>…要从中添加内容的文件。可以使用Fileglobs(例如*.c)来添加所有匹配的文件。<…>
请注意,这意味着您还可以执行以下操作:
git add **/main/*
添加主文件夹中的所有文件(未忽略)。你甚至可以用更复杂的模式来疯狂:
git add **/s?c/*Service*
上面将添加s(任意字符)c文件夹中的所有文件,并且文件名中有Service。
显然,每个命令不限于一个模式。也就是说,您可以要求git添加所有扩展名为.c和.h的文件:
git add *.c *.h
这个链接可能会给你更多的地球模式的想法。
我发现,当我进行许多更改时,它特别有用,但我仍然希望我的提交保持原子性,反映渐进的过程,而不是我当时可能正在进行的一大堆更改。当然,在某些情况下,提出复杂模式的成本超过了用更简单的方法添加文件,甚至一次添加一个文件的成本。然而,大多数时候,我可以很容易地用一个简单的模式找到我需要的文件,并排除所有其他文件。
顺便说一句,你可能需要引用你的glob模式来让它们工作,但我从来没有这样做过。
如果每次有三个有效的解决方案不涉及.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随后为此添加了特殊语法,其他答案对此进行了解释。
git add .
git reset main/dontcheckmein.txt
不是直接按照你的要求,因为它不是一个命令就能实现的,但结果应该是你想要的。
通过将所有文件添加到临时区域后
git add -u
键入gitstatus将建议您
git restore --staged main/dontcheckmein.txt