gitignore文件使用方法(gitignore教程)(git status --ignored)(git check-ignore -v <file>)
文章目录
- Gitignore文件
- 使用描述
- Gitignore基本语法
- 1. 基本语法★★★★★
- 2. 配置方法
- 匹配示例
- 示例1
- 示例2
- 示例3
- 其他命令
- `git status --ignored`(用于显示被Git忽略的文件和文件夹的状态)
- `git check-ignore -v <file>`(用于检查指定文件是否被Git忽略,并显示忽略规则的详细信息)
- 答疑
- 关于“否定模式`!`中,被先前模式排除的任何匹配文件将重新包含。如果排除了文件的父目录,则无法重新包含该文件”
- 如何取消已跟踪的文件?
- 示例
- 参考文章
Gitignore文件
Gitignore是一个用于指定Git版本控制系统忽略特定文件或目录的规则文件。它的发展可以追溯到早期的版本控制系统,如CVS和SVN,这些系统使用类似的机制来忽略特定文件。
在Git中,Gitignore文件的原理是通过定义一系列规则来告诉Git哪些文件应该被忽略。这些规则可以是简单的通配符模式,也可以是正则表达式。当Git执行某个操作时,如添加文件到版本控制或提交更改,它会检查Gitignore文件中的规则,并根据规则来决定是否忽略某个文件。
Gitignore文件的作用是帮助开发者过滤掉不需要被版本控制的文件,以减少仓库的体积和提高操作效率。它可以用于忽略一些临时文件、编译生成的文件、日志文件、配置文件等。通过忽略这些文件,可以使版本控制系统更加干净和专注于源代码的管理。
使用描述
一个.gitignore文件指定了Git应该忽略的意图上未跟踪的文件。已经被Git跟踪的文件不受影响;有关详细信息,请参阅下面的注释。
gitignore文件中的每一行都指定了一个模式。在决定是否忽略一个路径时,Git通常会从多个来源检查gitignore模式,按照以下优先顺序(在一个优先级级别内,最后匹配的模式决定结果):
对于支持它们的命令,从命令行读取的模式。
从与路径相同目录中的.gitignore文件,或者从任何父目录(直到工作树的顶级)中读取的模式,其中较高级别文件中的模式会被较低级别文件中的模式覆盖,直到包含该文件的目录。这些模式相对于.gitignore文件的位置进行匹配。一个项目通常会在其存储库中包含这样的.gitignore文件,其中包含作为项目构建的一部分生成的文件的模式。
从$GIT_DIR/info/exclude中读取的模式。
从由配置变量core.excludesFile指定的文件中读取的模式。
将模式放在哪个文件中取决于模式的使用方式。
应该进行版本控制并通过克隆分发到其他存储库(即,所有开发人员都希望忽略的文件)的模式应该放在.gitignore文件中。
特定于特定存储库但不需要与其他相关存储库共享的模式(例如,存储库内部但特定于一个用户工作流程的辅助文件)应该放在$GIT_DIR/info/exclude文件中。
用户希望Git在所有情况下都忽略的模式(例如,用户选择的编辑器生成的备份或临时文件)通常放在由core.excludesFile在用户的~/.gitconfig中指定的文件中。它的默认值是$XDG_CONFIG_HOME/git/ignore。如果$XDG_CONFIG_HOME未设置或为空,则使用$HOME/.config/git/ignore。
底层的Git工具,如git ls-files和git read-tree,从命令行选项指定的gitignore模式或从命令行选项指定的文件中读取。更高级别的Git工具,如git status和git add,使用上述来源中的模式。
Gitignore基本语法
Gitignore文件的基本使用方法是通过定义规则来告诉Git哪些文件应该被忽略。下面是Gitignore文件的基本语法和配置方法:
1. 基本语法★★★★★
- 空行不匹配任何文件,因此可以用作可读性的分隔符。
- 以“
#”开头的行作为注释。对于以“#”开头的模式,可以在第一个“#”前面加上反斜杠(“\”)。 - 尾随空格会被忽略,除非用反斜杠(“
\”)引用。 - 可选的前缀“
!”可以否定模式;被先前模式排除的任何匹配文件将重新包含。如果排除了文件的父目录,则无法重新包含该文件。出于性能原因,Git不会列出被排除的目录,因此对包含的文件的任何模式都没有影响,无论它们在何处定义。对于以字面“!”开头的模式,例如“\!important!.txt”,可以在第一个“!”前面加上反斜杠(“\”)。 - 斜杠“
/”用作目录分隔符。分隔符可以出现在.gitignore搜索模式的开头、中间或结尾。 - 如果模式的开头或中间(或两者都有)有分隔符
/,则该模式相对于特定.gitignore文件所在的目录级别。否则,该模式也可以在.gitignore级别以下的任何级别匹配。(比如a/b中间有斜杠,需要a与.gitignore同级才会被匹配,c/a/b不会匹配;/a同样) - 如果模式的结尾有分隔符
/,则该模式只匹配目录,否则该模式可以匹配文件和目录。 - 例如,模式
doc/frotz/匹配doc/frotz目录,但不匹配a/doc/frotz目录;但是frotz/匹配frotz和a/frotz这两个目录(所有路径都是相对于.gitignore文件的)。 - 星号“
*”匹配除斜杠以外的任何字符(可匹配多个字符组成的字符串,但字符串中不能包含斜杠/)。问号“?”匹配除斜杠以外的任何一个字符(只能匹配一个字符)。范围表示法,例如[a-zA-Z],可用于匹配范围内的一个字符。有关更详细的说明,请参阅fnmatch(3)和FNM_PATHNAME标志。 - 在与完整路径名匹配的模式中,两个连续的星号(“
**”)可能具有特殊含义:- 以“
**”开头的斜杠表示在所有目录中匹配。例如,“**/foo”匹配任何位置的文件或目录“foo”,与模式“foo”相同。“**/foo/bar”匹配直接位于目录“foo”下的文件或目录“bar”。 - 以“
/**”结尾的斜杠表示匹配其中的所有内容。例如,“abc/**”匹配相对于.gitignore文件位置的目录“abc”中的所有文件,具有无限深度。 - 斜杠后面跟着两个连续的星号然后是斜杠,表示匹配零个或多个目录。例如,“
a/**/b”匹配“a/b”、“a/x/b”、“a/x/y/b”等。
- 以“
- 其他连续的星号被视为普通的星号,并根据前面的规则进行匹配。
2. 配置方法
- 在项目根目录下创建一个名为
.gitignore的文件。 - 在
.gitignore文件中添加需要忽略的文件或目录的规则。 - 每行一个规则,可以使用上述基本语法来定义规则。
- 保存
.gitignore文件。
对于有多个目录的情况,想要忽略某种类型文件的目录和不想忽略的目录,可以在.gitignore文件中分别定义规则。例如,假设有两个目录dir1和dir2,想要忽略dir1目录下的.txt文件,但不想忽略dir2目录下的.txt文件,可以按照以下步骤进行配置:
-
在
.gitignore文件中添加以下规则:# 忽略dir1目录下的.txt文件 /dir1/*.txt -
在
dir2目录下创建一个名为.gitignore的文件。 -
在
dir2/.gitignore文件中添加以下规则:# 不忽略dir2目录下的.txt文件 !*.txt
这样配置后,Git会忽略dir1目录下的.txt文件,但不会忽略dir2目录下的.txt文件。注意,.gitignore文件的规则是逐级生效的,所以在dir2/.gitignore文件中使用!*.txt来取反,表示不忽略dir2目录下的.txt文件。
匹配示例
示例1
模式 hello.* 匹配以 hello. 开头的任何文件或目录。如果只想限制在目录中而不包括其子目录,可以在模式前加上斜杠,即 /hello.*;现在模式匹配 hello.txt、hello.c,但不匹配 a/hello.java。
模式 foo/ 匹配目录 foo 及其下面的路径,但不匹配普通文件或符号链接 foo(这与 Git 中 pathspec 的工作方式一致)。
模式 doc/frotz 和 /doc/frotz 在任何 .gitignore 文件中具有相同的效果。换句话说,如果模式中已经有中间斜杠,那么前导斜杠就不相关了。
模式 “foo/*” 匹配 “foo/test.json”(普通文件)、“foo/bar”(目录),但不匹配 “foo/bar/hello.c”(普通文件),因为模式中的星号不匹配带有斜杠的 “bar/hello.c”。
$ git status
[...]
# Untracked files:
[...]
# Documentation/foo.html
# Documentation/gitignore.html
# file.o
# lib.a
# src/internal.o
[...]
$ cat .git/info/exclude
# ignore objects and archives, anywhere in the tree.
*.[oa]
$ cat Documentation/.gitignore
# ignore generated html files,
*.html
# except foo.html which is maintained by hand
!foo.html
$ git status
[...]
# Untracked files:
[...]
# Documentation/foo.html
[...]
上面这段代码是一个示例,用来说明git中的文件忽略功能。在这个示例中,首先使用git status命令查看当前仓库的状态,发现有一些未跟踪的文件。然后,通过查看.git/info/exclude文件和Documentation/.gitignore文件,可以看到哪些文件被设置为忽略。最后再次使用git status命令查看仓库的状态,发现只有Documentation/foo.html文件没有被忽略。
示例2
$ cat .gitignore
vmlinux*
$ ls arch/foo/kernel/vm*
arch/foo/kernel/vmlinux.lds.S
$ echo '!/vmlinux*' >arch/foo/kernel/.gitignore
第二个 .gitignore 防止 Git 忽略 arch/foo/kernel/vmlinux.lds.S。
示例3
例子:排除除了特定目录 foo/bar 之外的所有内容(注意 /* - 如果没有斜杠,通配符也会排除 foo/bar 内的所有内容):
$ cat .gitignore
# 排除除了目录 foo/bar 之外的所有内容
/*
!/foo
/foo/*
!/foo/bar
其他命令
git status --ignored(用于显示被Git忽略的文件和文件夹的状态)
git status --ignored命令用于显示被Git忽略的文件和文件夹的状态。
Git有一个名为.gitignore的文件,用于指定哪些文件和文件夹应该被忽略,不纳入版本控制。这些被忽略的文件和文件夹不会出现在git status命令的输出中。
然而,有时候我们可能想要查看被忽略的文件和文件夹的状态,以确保我们的.gitignore文件配置正确。这时就可以使用git status --ignored命令。
以下是一个示例输出:
On branch master
Your branch is up to date with 'origin/master'.Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified: index.htmlIgnored files:(use "git add -f <file>..." to include in what will be committed)ignored_file.txtignored_folder/no changes added to commit (use "git add" and/or "git commit -a")
在上面的示例中,index.html文件被修改但未暂存,而ignored_file.txt和ignored_folder/被.gitignore文件忽略。
git check-ignore -v <file>(用于检查指定文件是否被Git忽略,并显示忽略规则的详细信息)
git check-ignore -v <file>命令用于检查指定文件是否被Git忽略,并显示忽略规则的详细信息。
当我们在使用.gitignore文件或其他忽略规则时,有时候我们想要验证某个文件是否被正确地忽略。这时就可以使用git check-ignore -v <file>命令。
以下是一个示例输出:
.gitignore:3:ignored_file.txt ignored_file.txt
在上面的示例中,.gitignore文件的第3行规则忽略了ignored_file.txt文件,并且git check-ignore -v命令显示了这个信息。
如果文件没有被忽略,那么该命令将不会有任何输出。
这个命令对于调试和验证忽略规则非常有用,可以帮助我们确保文件被正确地忽略。
答疑
关于“否定模式!中,被先前模式排除的任何匹配文件将重新包含。如果排除了文件的父目录,则无法重新包含该文件”
看一个示例:
我的/test/test/中有a.txt和b.txt两个文件(/test/test/与.gitignore同级)
模式1:
/*
!/test/test/
# !/test/
/test/test/*
!/test/test/a.txt
结果:

模式2:
/*
# !/test/test/
!/test/
/test/test/*
!/test/test/a.txt
结果:

就是说,在这个示例中,用/*排除了所有文件后,如果想恢复一个目录或者目录中的文件,一定要先恢复与/*同级下的这个目录或文件的最终父目录,在这个示例中是/test/目录,可以看到,恢复/test/test/是没有效果的。
如何取消已跟踪的文件?
比如已经有一些大文件已经被跟踪了,但是我们不想跟踪了,想在下一次提交的时候排除掉怎么办?
可以用:
git rm --cached <文件名/目录>
或者用通配符:
git rm --cached *.txt
或者用递归目录方式:
git rm --cached -r <文件夹路径>
示例
执行git rm --cached *.tar取消所有.tar文件的跟踪:

在.gitignore中增加一个*.tar:

执行git status --ignored查看,发现文件被取消跟踪了,那我们下次提交的时候,就不会把这些二文件提交上去了:


参考文章
https://git-scm.com/docs/gitignore
.gitignore文件作用及使用方法详解
Git – Ignore命令
相关文章:
gitignore文件使用方法(gitignore教程)(git status --ignored)(git check-ignore -v <file>)
文章目录 Gitignore文件使用描述Gitignore基本语法1. 基本语法★★★★★2. 配置方法 匹配示例示例1示例2示例3 其他命令git status --ignored(用于显示被Git忽略的文件和文件夹的状态)git check-ignore -v <file>(用于检查指定文件是否…...
mybatis拼接sql导致的oom报错 GC报错
报错1:mybatis拼接过多 java.lang.OutOfMemoryError: GC overhead limit exceeded 具体报错: nested exception is org.apache.ibatis.builder.BuilderException: Error evaluating expression ew.sqlSegment ! null and ew.sqlSegment ! and ew.non…...
如何通俗理解扩散模型?
扩散模型(Diffusion Model)是一类十分先进的基于扩散思想的深度学习生 成模型。生成模型除了扩散模型之外,还有出现较早的 VAE ( Variational Auto- Encoder,变分自编码器) 和 GAN ( Generative Adversarial Net ,生成对抗网络) 等。 虽然它们…...
【C#】并行编程实战:并行编程中的模式
本章将介绍并行编程模式,重点是理解并行代码问题场景并使用并行编程/异步技术解决他们。本章会介绍几种最重要的编程模式。 本教程学习工程:魔术师Dix / HandsOnParallelProgramming GitCode 1、MapReduce 模式 引入 MapReduce 是为了解决处理大数据的问…...
Apache Kafka 入门教程
Apache Kafka 入门教程 一、简介简介架构 二、Kafka 安装和配置JDK安装 Kafka配置文件详解 三、Kafka 的基本操作启动和关闭Topic 创建和删除Partitions 和 Replication 配置Producer 和 Consumer 使用方法ProducerConsumer 四、Kafka 高级应用消息的可靠性保证Kafka StreamKaf…...
python皮卡丘编程代码教程,用python打印皮卡丘
大家好,小编来为大家解答以下问题,如何用print函数打印一只皮卡丘,用python如何打印丘比特之心,现在让我们一起来看看吧!...
shell脚本:数据库的分库分表
#!/bin/bash ######################### #File name:db_fen.sh #Version:v1.0 #Email:admintest.com #Created time:2023-07-29 09:18:52 #Description: ########################## MySQL连接信息 db_user"root" db_password"RedHat123" db_cmd"-u${…...
AtCoder Beginner Contest 312(A~D)
A //语法题也要更仔细嘞,要不然也会wa #include <bits/stdc.h> // #pragma GCC optimize(3,"Ofast","inline") // #pragma GCC optimize(2) using namespace std; typedef long long LL; #define int LL typedef pair<int, int> …...
SQL中Partition的相关用法
使用Partition可以根据指定的列或表达式将数据分成多个分区。每个分区都是逻辑上独立的,可以单独进行查询、插入、更新和删除操作。Partition可以提高查询性能,因为它可以限制在特定分区上执行查询,而不是在整个表上执行。 在SQL中ÿ…...
微服务——Docker
docker与虚拟机的区别 首先要知道三个层次 硬件层:计算机硬件 内核层:与硬件交互,提供操作硬件的指令 应用层: 系统应用封装内核指令为函数,便于程序员调用。用户程序基于系统函数库实现功能。 docker在打包的时候直接把应用层的函数库也进行打包&a…...
测试|测试用例方法篇
测试|测试用例方法篇 文章目录 测试|测试用例方法篇1.测试用例的基本要素:测试环境,操作步骤,测试数据,预期结果…2.测试用例带来的好处3.测试用例的设计思路,设计方法,具体设计方法之间的关系**设计测试用…...
负载均衡的策略有哪些? 负载均衡的三种方式?
负载均衡的策略有哪些? 负载均衡的策略有如下: 1. 轮询(Round Robin):按照请求的顺序轮流分配到不同的服务器。 2. 权重(Weighted):给不同的服务器分配不同的权重,根据权重比例来…...
二十三章:抗对抗性操纵的弱监督和半监督语义分割的属性解释
0.摘要 弱监督语义分割从分类器中生成像素级定位,但往往会限制其关注目标对象的一个小的区域。AdvCAM是一种图像的属性图,通过增加分类分数来进行操作。这种操作以反对抗的方式实现,沿着像素梯度的相反方向扰动图像。它迫使最初被认为不具有区…...
curator实现的zookeeper可重入锁
Curator是一个Apache开源的ZooKeeper客户端库,它提供了许多高级特性和工具类,用于简化在分布式环境中使用ZooKeeper的开发。其中之一就是可重入锁。 Curator提供了InterProcessMutex类来实现可重入锁。以下是使用Curator实现ZooKeeper可重入锁的示例&am…...
抽象工厂模式——产品族的创建
1、简介 1.1、简介 抽象工厂模式为创建一组对象提供了一种解决方案。与工厂方法模式相比,抽象工厂模式中的具体工厂不只是创建一种产品,它负责创建一族产品 1.2、定义 抽象工厂模式(Abstract Factory Pattern):提供…...
【C语言初阶篇】自定义类型结构体我不允许还有人不会!
🎬 鸽芷咕:个人主页 🔥 个人专栏:《C语言初阶篇》 《C语言进阶篇》 ⛺️生活的理想,就是为了理想的生活! 文章目录 📋 前言1 . 什么是结构体1.1 结构的定义1.2 结构的声明 2.结构体初始化2.1 用标签名定义和初始化2.2…...
重大更新|Sui主网即将上线流动性质押,助力资产再流通
Sui社区一直提议官方上线流动质押功能,现在通过SIP过程,已经升级该协议以实现这一功能。 Sui使用委托权益证明机制(DPoS)来选择和奖励负责运营网络的验证节点。为了保障网络安全,验证节点通过质押SUI token获得质押奖…...
day3 驱动开发 c语言编程
通过ioctl(内核应用层) 控制led灯三盏,风扇,蜂鸣器,小马达 头文件head.h #ifndef __LED_H__ #define __LED_H__typedef struct {volatile unsigned int TZCR; // 0x000volatile unsigned int res1[2]; // 0x…...
【字节跳动青训营】后端笔记整理-3 | Go语言工程实践之测试
**本文由博主本人整理自第六届字节跳动青训营(后端组),首发于稀土掘金:🔗Go语言工程实践之测试 | 青训营 目录 一、概述 1、回归测试 2、集成测试 3、单元测试 二、单元测试 1、流程 2、规则 3、单元测试的例…...
【Android】Recyclerview的缓存复用
介绍 RecyclerView是Android开发中常用的一个高度可定制的列表视图组件。它是在ListView和GridView的基础上进行了改进和增强,旨在提供更好的性能和更灵活的布局管理。 RecyclerView的主要特点如下: 灵活的布局管理器(LayoutManager&#…...
Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
MVC 数据库
MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...
spring:实例工厂方法获取bean
spring处理使用静态工厂方法获取bean实例,也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下: 定义实例工厂类(Java代码),定义实例工厂(xml),定义调用实例工厂ÿ…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)
骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术,它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton):由层级结构的骨头组成,类似于人体骨骼蒙皮 (Mesh Skinning):将模型网格顶点绑定到骨骼上,使骨骼移动…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...
浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...
