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-filesgit read-tree,从命令行选项指定的gitignore模式或从命令行选项指定的文件中读取。更高级别的Git工具,如git statusgit 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/匹配frotza/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文件中分别定义规则。例如,假设有两个目录dir1dir2,想要忽略dir1目录下的.txt文件,但不想忽略dir2目录下的.txt文件,可以按照以下步骤进行配置:

  1. .gitignore文件中添加以下规则:

    # 忽略dir1目录下的.txt文件
    /dir1/*.txt
    
  2. dir2目录下创建一个名为.gitignore的文件。

  3. dir2/.gitignore文件中添加以下规则:

    # 不忽略dir2目录下的.txt文件
    !*.txt
    

这样配置后,Git会忽略dir1目录下的.txt文件,但不会忽略dir2目录下的.txt文件。注意,.gitignore文件的规则是逐级生效的,所以在dir2/.gitignore文件中使用!*.txt来取反,表示不忽略dir2目录下的.txt文件。

匹配示例

示例1

模式 hello.* 匹配以 hello. 开头的任何文件或目录。如果只想限制在目录中而不包括其子目录,可以在模式前加上斜杠,即 /hello.*;现在模式匹配 hello.txthello.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.txtignored_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.txtb.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命令

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/14885.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一个灵活、现代的Android应用架构

一个灵活、现代的Android应用架构 学习Android架构的原则&#xff1a;学习原则&#xff0c;不要盲目遵循规则。 本文旨在通过示例演示实际应用&#xff1a;通过示范Android架构来进行教学。最重要的是&#xff0c;这意味着展示出如何做出各种架构决策。在某些情况下&#xff0…

网络层IP协议的基本原理 数据链路层ARP协议 域名解析以及一些重要技术

目录 1 网络层IP协议协议头格式网段划分DHCPCIDR&#xff1a;基于子网掩码的划分方式特殊的IP号IP地址的数量限制私有IP地址和公网IP地址路由路由表 2 数据链路层 — 局域网的转发问题以太网认识以太网以太网帧格式局域网通信原理 MTUMTU对IP协议的影响MTU对UDP协议的影响MTU对…

人类文明进入下个纪元奇点:UFO听证会-恒温超导发现-GPT大模型

今年以来&#xff0c;科技领域出圈的事件频繁发生&#xff0c;每一个事件都意味着一个领域的重大突破的可能。这些事件是UFO听证会、恒温超导LK99的论文、GPT类大模型的广泛应用&#xff0c;我常将这些事件串在一起思考&#xff0c;细思极恐&#xff0c;一种”火鸡与农场主“的…

C语言手撕顺序表

目录 一、概念 1、静态顺序表&#xff1a;使用定长数组存储元素。 2、动态顺序表&#xff1a;使用动态开辟的数组存储 二、接口实现 1、对顺序表的初始化 2、对数据的销毁 3、对数据的打印 4、检查是否需要扩容 5、尾插 6、头插 7、尾删 8、头删 9、在pos位置插入x …

使用ComPDFKit PDF SDK 构建iOS PDF阅读器

在当今以移动为先的世界中&#xff0c;为企业和开发人员创建一个iOS应用程序是必不可少的。随着对PDF文档处理需求的增加&#xff0c;使用ComPDFKit这个强大的PDF软件开发工具包&#xff08;SDK&#xff09;来构建iOS PDF阅读器和编辑器可以让最终用户轻松查看和编辑PDF文档。 …

IDEA 模块不加载依旧是灰色 没有变成小蓝色的方块

Settings > Build, Execution, Deployment > Build Tools > Maven > Ignored Files下降对应的模块勾选掉 但通常在Maven的配置中&#xff0c;您会找到一个名为“ignoredFiles”的列表&#xff0c;其中包含被忽略的文件和目录。您可以通过取消选中所需的文件或目录…

本地非文字资源无法加载

目录 方法A.静态/动态绑定路径 方法B.require导入&#xff08;运行时加载&#xff09; 方法C.import导入&#xff08;x&#xff09;&#xff08;编译时加载&#xff09; 方法D.ref直接操作元素赋值&#xff08;x&#xff09; 相关知识 import和requir区别 模板路径&#…

基于opencv与机器学习的摄像头实时识别数字!附带完整的代码、数据集和训练模型!!

前言 使用摄像头实时识别数字算是目标检测任务&#xff0c;总体上分为两步&#xff0c;第一步是检测到数字卡片的位置&#xff0c;第二步是对检测到的数字卡片进行分类以确定其是哪个数字。在第一步中主要涉及opencv的相关功能&#xff0c;第二步则使用机器学习的方式进行分类…

源码学习初章-基础知识储备

文章目录 学前准备源码地址引言extern "C" 宏定义平台宏跨平台宏vstdio平台禁用警告宏 连接、双层宏定义函数宏系统函数宏自定义函数宏多语句执行宏do while0 普通宏定义 C的一些必备函数知识回调函数和函数指针回调函数wireshark-4.0.7源码例子函数指针wireshark4.0…

通讯录的实现(超详细)——C语言(进阶)

目录 一、创建联系人信息&#xff08;结构体&#xff09; 二、创建通讯录&#xff08;结构体&#xff09; 三、define定义常量 四、打印通讯录菜单 五、枚举菜单选项 六、初始化通讯录 七、实现通讯的的功能 7.1 增加加联系人 7.2 显示所有联系人的信息 ​7.3 单独查…

《MySQL45讲》笔记—索引

索引 索引是为了提高数据查询效率&#xff0c;就像书的目录一样。如下图&#xff0c;索引和数据就是位于存储引擎中&#xff1a; 索引常见模型 哈希表 以键值对存储的数据结构。适用于只有等值查询的场景。 有序数组 在等值查询和范围查询场景中性能都特别优秀。但是有…

开放自动化软件的硬件平台

自动化行业的产品主要以嵌入式系统为主&#xff0c;历来对产品硬件的可靠性和性能都提出很高的要求。最典型的产品要数PLC。PLC 要求满足体积小&#xff0c;实时性&#xff0c;可靠性&#xff0c;可扩展性强&#xff0c;环境要求高等特点。它们通常采用工业级高性能嵌入式SoC 实…

Vue 3:玩一下web前端技术(三)

前言 本章内容为VUE工作过程与相关使用讨论。 上一篇文章地址&#xff1a; Vue 3&#xff1a;玩一下web前端技术&#xff08;二&#xff09;_Lion King的博客-CSDN博客 下一篇文章地址&#xff1a; Vue 3&#xff1a;玩一下web前端技术&#xff08;四&#xff09;_Lion Ki…

SpringBoot 注解

SpringBoot SpringBoot&#xff08;SpringBootApplication&#xff09;问题引入我们的工程在引入spring-boot-starter-web依赖的时候&#xff0c;为什么没有指定版本&#xff08;版本锁定&#xff09;spring-boot-starter-web是个啥&#xff0c;为什么引入了它之后&#xff0c;…

【业务功能篇59】Springboot + Spring Security 权限管理 【下篇】

UserDetails接口定义了以下方法&#xff1a; getAuthorities(): 返回用户被授予的权限集合。这个方法返回的是一个集合类型&#xff0c;其中每个元素都是一个GrantedAuthority对象&#xff0c;表示用户被授予的权限。getPassword(): 返回用户的密码。这个方法返回的是一个字符…

springboot编写mp4视频播放接口

简单粗暴方式 直接读取指定文件&#xff0c;用文件流读取视频文件&#xff0c;输出到响应中 GetMapping("/display1/{fileName}")public void displayMp41(HttpServletRequest request, HttpServletResponse response,PathVariable("fileName") String fi…

stm32通过ESP8266接入原子云

1. ESP8266模块需要烧录原子云固件&#xff0c;此原子云固件和正常的ESP8266固件相比添加了ATATKCLDSTA 和 ATATKCLDCLS 这两条指令&#xff1a; 2. 原子云账号注册及设备建立 设备管理-新增设备-ESP8266 新建设备后新建分组&#xff0c;将设备加入到此分组中&#xff1a; 至此…

ICASSP 2023 | Cough Detection Using Millimeter-Wave FMCW Radar

原文链接&#xff1a;https://mp.weixin.qq.com/s?__bizMzg4MjgxMjgyMg&mid2247486540&idx1&sn6ebd9f58e9f08a369904f9c48e12d136&chksmcf51beb5f82637a3c65cf6fa53e8aa136021e35f63a58fdd7154fc486a285ecde8b8521fa499#rd ICASSP 2023 | Cough Detection Usi…

SwipeDelMenuLayout失效:Could not find SwipeDelMenuLayout-V1.3.0.jar

一、问题描述 最近在工作上的项目中接触到SwipeDelMenuLayout这个第三方Android开发库&#xff0c;然后我就根据网上的教程进行配置。这里先说一下我的开发环境&#xff1a;Android Studio版本是android-studio-2020.3.1.24-windows&#xff0c;gradle版本是7.0.2。 首先是在se…

RWEQ模型——土壤风蚀模拟

详情点击链接&#xff1a;基于“RWEQ”集成技术在土壤风蚀模拟与风蚀模数估算、变化归因分析中的实践应用及SCI论文撰写 前沿 土壤风蚀是一个全球性的环境问题。中国是世界上受土壤风蚀危害最严重的国家之一&#xff0c;土壤风蚀是中国干旱、半干旱及部分湿润地区土地荒漠化的…