我已经在我的机器上设置了一个本地git。初始化git时,我添加了预编译的库和二进制文件。然而,现在在我的开发过程中,我不想间歇性地签入这些文件。我不想从回购中删除这些文件。是否有任何方法不跟踪这些文件,直到我完成我的开发。(我想我不能使用.gitignore,因为它只适用于那些不在git中的文件。我想暂时禁用文件跟踪。)
当前回答
我假设您正在询问如何删除构建文件夹或bin文件夹中的所有文件,而不是分别选择每个文件。
您可以使用该命令: Git rm -r -f /build\* 确保您在构建目录的父目录中。 这个命令将递归地“删除”bin/或build/文件夹中的所有文件。我的意思是git会假装那些文件被“删除”了,并且这些文件不会被跟踪。git实际上将这些文件标记为删除模式。
请确保为即将提交的.gitignore准备好了。 文档:git rm
其他回答
我假设您正在询问如何删除构建文件夹或bin文件夹中的所有文件,而不是分别选择每个文件。
您可以使用该命令: Git rm -r -f /build\* 确保您在构建目录的父目录中。 这个命令将递归地“删除”bin/或build/文件夹中的所有文件。我的意思是git会假装那些文件被“删除”了,并且这些文件不会被跟踪。git实际上将这些文件标记为删除模式。
请确保为即将提交的.gitignore准备好了。 文档:git rm
假设不变的替代方法是skip-worktree。后者有不同的含义,类似于“Git不应该跟踪这个文件。开发者可以(也被鼓励)在本地做出改变。”
在您不希望跟踪构建文件的更改(通常是较大的)的情况下,假设—unchanged是一个不错的选择。
在这种情况下,文件应该有默认内容,开发人员可以自由地在本地修改文件,但不应该检查他们的本地更改回到远程回购,跳过工作树是一个更好的选择。
另一个优雅的选择是在repo中有一个默认文件。假设文件名是BuildConfig.Default.cfg。开发人员需要在本地将其重命名为BuildConfig.cfg,并且他们可以进行所需的任何本地更改。现在将BuildConfig.cfg添加到.gitignore中,这样文件就不会被跟踪了。
看这个问题,在公认的答案中有一些很好的背景信息。
手册在2.4节中提到了这一点:“撤销事情”。基本上,您需要做的是将某些文件的索引状态重置为HEAD状态,即最近一次签出(或提交)时的状态。这将取消将文件暂存到当前索引。本任务的命令为git reset.[1]
所以,你要执行的命令是:
git reset HEAD /path/to/file
新版本的git(我相信从1.6左右开始)在执行git status时给出了这个命令(以及更多)作为提示。这些版本是非常用户友好的。一个个人建议:如果你只是暂存几个文件,使用git add -i。这将启动交互式登台工具,这使事情变得特别简单。此外,我强烈推荐阅读这本书,因为它非常明确地介绍了git在实际情况中的使用。
[1] http://www.git-scm.com/book
Run
git rm -r --cached file_to_git_ignore
那就去找你的gitignore档案 并添加path_to_file_to_git_ignore
祝你好运
你可以让你的文件不被追踪
git rm -r --cached <file>
使用
git add -u
他们会推你或者做任何你想做的事。
推荐文章
- 如何点Go模块的依赖在Go。Mod到回购中的最新提交?
- 乳胶渲染在README。md在Github上
- 为什么调用git分支——unset-upstream来修复?
- Windows git“警告:LF将被CRLF取代”,这是警告尾巴向后吗?
- git中的哈希冲突
- git可以自动在空格和制表符之间切换吗?
- Git暂存文件列表
- 在Markdown Jekyll中使用图像说明
- 如何将git配置存储为存储库的一部分?
- 如何修改GitHub拉请求?
- 如何在Github和本地删除最后n次提交?
- 我如何调试git/git-shell相关的问题?
- 错误:无法使用rebase进行拉取:您有未分阶段的更改
- Git隐藏未缓存:如何把所有未分期的变化?
- 如何将文件附加到GitHub问题?