我克隆了一个包含一些.csproj文件的项目。我不需要/喜欢我的本地csproj文件被Git跟踪(或在创建补丁时被提起),但很明显,项目中需要这些文件。

我已经将*.csproj添加到我的LOCAL.gitignore中,但文件已经在repo中。

当我键入gitstatus时,它显示了我对csproj的更改,我对跟踪或提交补丁程序不感兴趣。

如何从我的个人存储库中删除这些文件的“跟踪”(但将它们保存在源中,以便我可以使用它们),以便我在执行状态(或创建补丁)时不会看到更改?

是否有正确/规范的方法来处理这种情况?


当前回答

接受的答案对我仍然不起作用

我用过

git rm-r--缓存。git添加。gitcommit-m“正在修复.gitignore”

从这里找到答案

其他回答

为了节省一些时间,您添加到.gitignore中的规则可以用于删除多个文件/文件夹,即。

git rm--缓存的app/**/*.xml

or

git rm--缓存的-r app/widgets/yourfolder/

电子交易中心。

忘了你的gitignore?

如果您在本地拥有整个项目,但忘记添加git-ignore,现在正在跟踪一些不必要的文件,请使用此命令删除所有内容

git rm --cached -r .

确保您处于项目的根位置。

然后你可以像往常一样

Add

git add .

犯罪

git commit -m 'removed all and added with git ignore'

Push

git push origin master

结论

希望这能帮助那些不得不对自己的.git进行更改的人。

它会删除整个缓存看看你的.gitignore添加要跟踪的文件推送至您的回购

这是一个两步过程:

删除对文件/文件夹的跟踪-但将其保留在磁盘上-使用git rm—缓存现在,它们没有显示为“已更改”,但仍显示为git状态为-u的未跟踪文件将它们添加到.gitignore

防止git监视文件或路径

git update-index --assume-unchanged [file-path]

并将其恢复使用

git update-index --no-assume-unchanged [file-path]

参考类似用例的回购https://github.com/awslabs/git-secrets

在这个答案中给出了一个几乎无需git命令的方法:

要忽略每个本地存储库的某些文件,请执行以下操作:

创建文件~/.gitignore_global,例如在终端中使用touch~/.gotignore_gglobal。运行git-config--global-core.excludsfile~/.gitignore_global一次。将要忽略的文件/dir路径写入~/.gitignore_global.example-modules/*.H,该路径将被假定为在您的工作目录中,即$WORK_dir/modules/*.H。

要忽略单个本地存储库的某些文件,请执行以下操作:

对repo中的文件.git/info/exclude执行上述第三步,即将要忽略的文件/dir路径写入.git/info/dexclude中,例如modules/*.C,它将被假定在您的工作目录中,即$WORK_dir/modules/*.C。