前面介绍了如何忽略以特定后缀结尾的所有文件 。如果您想要做一个例外,并且有一个带有该后缀的文件不想忽略,会发生什么情况呢?
假设你在.gitignore
文件中添加了以下内容:
.md该模式忽略所有以.md
结尾的文件,但您不希望Git忽略README.md
文件 。
要做到这一点,您需要使用带有感叹号的否定模式,!
,来使该文件失效,否则该文件将会被忽略:
# ignores all .md files.md# does not ignore the README.md file!README.md对于.gitignore
文件中的这两种模式,所有以.md
结尾的文件都会被忽略,除了README.md
文件 。
要注意的是 , 如果忽略整个目录 , 此模式将不起作用 。
假设你忽略了所有的测试目录:
test/
假设在一个测试文件夹中,有一个文件 , 例如.Md
,你不想忽视的 。
你不能像这样对一个被忽略的目录中的文件进行否定:
# ignore all directories with the name testtest/# trying to negate a file inside an ignored directory won't work!test/example.md如何忽略之前提交的文件
最好的做法是创建一个.gitignore文件,其中包含创建新存储库时要忽略的所有文件和不同的文件模式——在提交之前 。
Git只能忽略尚未提交到存储库的未跟踪文件 。
如果您在过去已经提交了一个文件,但希望没有提交该怎么办?
假设您不小心提交了一个存储环境变量的.env
文件 。
你首先需要更新.gitignore
文件以包含.env
文件:
# add .env file to .gitignoreecho ".env" >> .gitignore现在,你需要告诉Git不要跟踪这个文件,把它从索引中删除(如果是文件夹需要添加-r
选项):
git rm --cached .envgit rm
命令和--cached
选项一起从存储库中删除文件 , 但不删除实际的文件 。这意味着该文件作为一个被忽略的文件保留在您的本地系统和工作目录中 。
git status
将显示该文件已不在存储库中,而输入ls
命令将显示该文件存在于本地文件系统中 。
如果希望从存储库和本地系统中删除文件,请忽略--cached
选项 。
接下来,使用git add
命令将.gitignore
添加到暂存区:
git add .gitignore最后,使用git commit
命令提交.gitignore
文件:
git commit -m "update ignored files"【git中 gitignore 忽略文件操作】
推荐阅读
- 奥拉星手游石板解谜1
- 一 『现学现忘』Git后悔药 — 32、revert撤销
- 原神妮露阵容怎么搭配
- 怎样在大海中游泳(在大海中怎么游泳)
- Java一次返回中国所有省市区三级树形级联+前端vue展示【200ms内】
- C++ 使用栈求解中缀、后缀表达式的值
- 小小蚁国中期进化类型怎么选择
- 中国六大草原排名-中国有哪四大草原
- 国行ps5会锁区吗_国行ps5锁服不锁区
- 中国疫苗有效率是多少_中国新冠疫苗有效率