1. 背景

前提知识:在工作目录下的每一个文件都不外乎有两种状态:已追踪(tracked),或者 未追踪(untracked)。

在使用Git管理项目的时候,可能会用到一些文件,但是这些文件我们又不想提交到Git进行管理。

比如

  • 忽略操作系统自动生成的文件,比如缩略图等;
  • 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件;
  • 忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件;
  • 代码运行过程中产生的,.log文件,.html文件;

每次提交的时候,由于这些文件尚未被Git追踪,都会提醒 Untracked files...,但是我们又不想让Git来管理这些文件。

这篇文章就来介绍,怎么让 Git忽略掉这些文件,不再每次提醒我们。


2. 创建.gitignore 文件

我们在项目的根目录下,创建一个名为 .gitignore的文件。

$ touch .gitignore

列出要忽略的文件的模式。

*.log
.idea/**/workspace.xml

第一行表示,忽略当前目录下 以及 子目录下所有的 .log文件。

第二行表示,忽略 .idea目录下 及其子目录下,所有的 workspace.xml文件

这样,就可以把 .gitignore文件提交到Git进行版本管理,其他人拉下来项目的时候也就自动生效了。


3. 文件内容样式

.gitignore文件遵循以下规范

  1. 所有空行或者以 # 开头的行都会被 Git 忽略。

  2. 可以使用标准的 glob 模式匹配,它会递归地应用在整个工作区中。

  3. 匹配模式可以以(/)开头防止递归。

  4. 匹配模式可以以(/)结尾指定目录。

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

其中所谓的 glob 模式是指 shell 所使用的简化了的正则表达式。 遵守以下规范

  • 星号(*)匹配零个或多个任意字符;
  • [abc] 匹配任何一个列在方括号中的字符 (这个例子要么匹配一个 a,要么匹配一个 b,要么匹配一个 c);
  • 问号(?)只匹配一个任意字符;
  • 如果在方括号中使用短划线分隔两个字符, 表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。
  • 使用两个星号(//)表示匹配任意中间目录,比如 a/**/z 可以匹配 a/z 、 a/b/z 或 a/b/c/z 等。

一个 .gitignore的例子

# 忽略所有的 .a 文件
*.a # 但跟踪所有的 lib.a,即便你在前面忽略了 .a 文件
!lib.a # 只忽略当前目录下的 TODO 文件,而不忽略 subdir/TODO
/TODO # 忽略任何目录下名为 build 的文件夹
build/ # 忽略 doc/notes.txt,但不忽略 doc/server/arch.txt
doc/*.txt # 忽略 doc/ 目录及其所有子目录下的 .pdf 文件
doc/**/*.pdf

Note:

有些时候,你想添加一个文件到Git,但发现添加不了,原因是这个文件被.gitignore忽略了:

$ git add App.class
The following paths are ignored by one of your .gitignore files:
App.class
Use -f if you really want to add them.

如果你确实想添加该文件,可以用 -f 强制添加到Git:

$ git add -f App.class

或者你发现,可能是.gitignore写得有问题,需要找出来到底哪个规则写错了,可以用git check-ignore命令检查:

$ git check-ignore -v App.class
.gitignore:3:*.class App.class

4. exclude文件

exclude文件在 ,exclude文件跟 .ignore文件的效果类似,都可以忽略掉某些文件。不同点在于

  • exclude文件位于当前项目的 .git/info/exlude目录下, .gitignore文件位于 当前项目的根目录下
  • exclude文件只在本地有效,无法git add,跟别人共享, .gitignore文件可上传到Git进行版本管理

5. gitignore 文件模板

我们不需要自己写 .gitignore文件,以下两种方式帮你提供了

github/gitignore

Git官方维护了一个仓库,里面有各种语言下需要 ignore 的文件,我们只需要根据需要,自己组合一下就能用了。

根目录下包括 主流语言的模板,通常情况下用这个就够用了。

Global文件夹里面包括,各类的编辑器、工具以及操作系统,比如 Matlab, JetBrain, linux, VisualStudioCode。

community文件夹里包括一些非主流的 语言、工具以及项目。

gitignore.io

我们的项目必须忽略的文件是由三部分构成的,操作系统 + IDE + 语言,这三种还得组合起来,以上是一个开源网站。

比如我们目前使用的是Intellij + Java,只需要在搜索框中搜索以上关键词,就可以生成这我们需要的 .gitignore文件。

https://www.toptal.com/developers/gitignore/api/intellij,java


6. 参考文档

Git使用 - 忽略特定文件 - gitignore的更多相关文章

  1. git跟踪忽略规则文件.gitignore

    在使用Git的过程中,我们希望有的文件比如临时文件,编译的中间文件等不要被跟踪,也不需要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这些文件的提交. 配置语法 以斜杠"/"开 ...

  2. Git始终忽略特定文件的某一行内容

    笔者在编写Z Shell文件的时候经常会使用到set -x来开启调试,但不希望提交到仓库 解决方案 Git提供了一种文件过滤器,此方法可以帮助在提交时移除set -x 我们先来编写脚本,如何移除这一行 ...

  3. Android studio 开发中 用git实现批量忽略特定文件的方法

    git实现批量忽略特定文件的方法 在用AndroidStudio开发项目的时候,3个人协同开发,那么用Git同步代码,会将模块中的大量iml文件同步,每次都会提交和更新,一个一个的去忽略他们,显然是最 ...

  4. 版本控制git之四-忽略特殊文件

    版本控制git之四-忽略特殊文件   有些时候,你必须把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件啦,等等,每次git status都会显示Untracked fi ...

  5. git操作忽略.iml文件

    git操作忽略.iml文件** 参考:https://blog.csdn.net/m0_38001814/article/details/87354584 因为.iml文件的修改导致代码pull失败 ...

  6. 14.Git忽略特殊文件.gitignore

    有些时候,你必须把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件啦,等等,每次git status都会显示Untracked files ...,有强迫症的童鞋心里肯定 ...

  7. Git 忽略特定文件或文件夹

    在代码编译过程中,可能会生成一些目标文件或其他我们不希望提交到服务器的文件或文件夹, 但是因为是生成出来的文件/文件夹,在每次使用git status 查看状态的时候git系统总会提示这些 文件或文件 ...

  8. Git学习之忽略特殊文件.gitignore的配置

    1.Mac中使用Git上传项目代码时忽略.DS_Store文件 简单的说Mac每个目录都会有个文件叫.DS_Store,它是用于存储当前文件夹的一些Meta信息.所以每次查看Git目录的状态,如果没有 ...

  9. git设置忽略某些文件或文件夹

    在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法.如果没有 .gitignore 文件,就自己创建一个,手动创建会提示你输入文件名称,因此,你 ...

随机推荐

  1. 设计模式学习笔记(十四)责任链模式实现以及在Filter中的应用

    责任链模式(Chain Of Responsibility Design Pattern),也叫做职责链,是将请求的发送和接收解耦,让多个接收对象都有机会处理这个请求.当有请求发生时,可将请求沿着这条 ...

  2. python2.7安装pyinstaller

    python2.7直接安装pyinstaller会报错,版本4与python2不兼容,所以我们安装时需指定兼容的pyinstaller版本号.安装命令如下: pip2 install pyinstal ...

  3. Struts2-从值栈获取list集合数据(三种方式)

    创建User封装数据类 public class User { private String username; private String password; public String getP ...

  4. LC-977

    给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序. 示例 1: 输入:nums = [-4,-1,0,3,10] 输出:[0,1,9,1 ...

  5. Java进阶 JVM 内存与垃圾回收篇(一)

    JVM 1. 引言 1.1 什么是JVM? 定义 Java Vritual Machine - java 程序的运行环境(Java二进制字节码的运行环境) 好处 一次编译 ,到处运行 自动内存管理,垃 ...

  6. Java学习day23

    今天学习了下拉框实现与简单游戏的实现 package com.Cra2iTeT.snake; import javax.swing.*; import java.awt.*; import java. ...

  7. Docker安装Opensips2.4实现内网sip电话通讯

    使用说明 这是基于官方opensips 2.4镜像添加了mysql模块以及rest_client模块制作的镜像,用此镜像可以连接mysql控制opensip注册用户.查看通话记录以及通话时对INVIT ...

  8. Amazing!巧用 CSS 视差实现酷炫交互动效

    本文将介绍利用 CSS 实现滚动视差效果的一个小技巧,并且,利用这个技巧来制作一些有意思的交互特效. 关于使用 CSS 实现滚动视差效果,在之前有一篇文章详细描述过具体方案 - CSS 实现视差效果, ...

  9. 微博python爬虫weiboSpider注意事项

    首先我看的weiboSpider爬虫项目教程出自https://github.com/dataabc/weiboSpider 1.这爬取的是手机端的,所以我把网址https://weibo.com的. ...

  10. GO语言学习——切片二

    使用make()函数构造切片 格式: make([]T, size, cap) 其中: T:切片的元素类型 size:切片中元素的数量 cap:切片的容量 切片的本质 切片的本质就是对底层数组的封装, ...