【Git第七节】忽略文件

同学们!欢迎大家来到Python自学教程教室,上节课我们带大家学习了文件状态的相关内容,这节课我们学习忽略文件的相关内容,你准备好了吗?

在文件夹中,经常会有些“其他”文件,比如上节课最后提到的,编辑器产生~结尾的备份文件,或者一些临时文件。又可能,某些文件我们只是在本地使用,并不想提交到远程的仓库中被别人看到。但如果我们不跟踪这些文件,Git会一直很执着地提醒我们工作目录中有一些未被跟踪的文件。如果你想清净一点,就可以通过.gitignore文件忽略你不想看到的文件。

要感受一下忽略文件的效果,首先你得有打算忽略的文件,所以我们强行创建一个叫做readme.txt.tmp的文件,假设它是readme.txt产生的临时文件。

git status 看一下效果,同上节课中一样,在untracked files里列出了这个文件:

# On branch master

# Untracked files:

# (use "git add <file>..." to include in what will be committed)

#

# readme.txt.tmp

othing added to commit but untracked files present (use "git add" to track)

然后我们在工作目录中新建一个.gitignore文件,在里面写上一行:

*tmp

保存退出,再运行 git status:

# On branch master

# Untracked files:

# (use "git add <file>..." to include in what will be committed)

#

# .gitignore

othing added to commit but untracked files present (use "git add" to track)

readme.txt.tmp文件消失了,untracked files里只剩下刚创建的.gitignore文件。

来看一下《Pro Git》里对.gitignore格式规范的解释

所有空行或者以注释符号 # 开头的行都会被 Git 忽略。

可以使用标准的 glob 模式匹配。

匹配模式最后跟反斜杠(/)说明要忽略的是目录。

要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反。

所谓的 glob 模式是指 shell 所使用的简化了的正则表达式:

星号(*)匹配零个或多个任意字符;

[abc] 匹配任何一个列在方括号中的字符(这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);

问号(?)只匹配一个任意字符;

如果在方括号中使用短划线分隔两个字符,表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。

所以我们前面写的 *tmp,就是指忽略所有以tmp结尾的文件。

再来看一个 .gitignore 文件的例子:

# 此为注释 – 将被 Git 忽略

# 忽略所有 .a 结尾的文件

*.a

# 但 lib.a 除外

!lib.a

# 仅仅忽略项目根目录下的 TODO 文件

# 不包括 subdir/TODO

/TODO

# 忽略 build/ 目录下的所有文件

build/

# 忽略 doc 目录下的所有 .txt 文件

# 会忽略 doc/notes.txt

# 但不包括 doc/server/arch.txt

doc/*.txt

当然,你也可以把.gitignore文件本身从git中忽略。但我不建议这么做,而是所有协作开发者使用统一的规范,避免有人因为没写.gitignore而提交上去一些奇怪的文件。

在项目一开始就把.gitignore设置好,不仅是为了好看,也是避免不必要的文件对代码产生干扰。比如有些需要本地生成的文件,如果放在远程仓库中被其他人下载使用,也可能会导致程序无法正常运行。

恭喜您在Python自学的道路上又坚持了一天,今天我们所讲的忽略文件的相关内容你都学会了吗?你都理解清楚了吗?下节更精彩,敬请期待!

好啦,今天的分享到这里就结束了,希望大家持续关注马哥教育官网,每天都会有大量优质内容与大家分享!

声明:文章来源于网络,侵删!

相关新闻

历经多年发展,已成为国内好评如潮的Linux云计算运维、SRE、Devops、网络安全、云原生、Go、Python开发专业人才培训机构!