【Git】.gitignore 的匹配规则

  1. 每行一个规则:每行只能包含一个规则,多个规则需要分别写在不同的行上。

    示例:

    复制代码
    # 忽略日志文件
    logs/
    # 忽略临时文件
    temp.txt
  2. 种类匹配:

    • 文件:在规则的开头指定文件名或路径,如 file.txt

    示例:

    复制代码
    # 忽略文件 file.txt
    file.txt
    # 忽略同名目录或者文件(不论嵌套)
    dist
    • 目录:在规则的开头用斜杠 / 指定目录名或路径,如 /dir/

    示例:

    复制代码
    # 忽略目录 dir(从当前目录出发寻找)
    /dir/
    
    # 忽略目录或者文件 dir(从当前目录出发寻找)
    dir
    # 忽略目录或者文件 dir(从当前目录出发寻找)
    /dir
    • 通配符:

      • *:匹配任意数量(0个或多个)的字符,但不包括路径分隔符(斜杠)。

      示例:

      复制代码
      # 忽略所有 .txt 结尾的文件
      *.txt
      • ?:匹配单个字符,但不包括路径分隔符。

      示例:

      复制代码
      # 忽略 a.txt 或 aa.txt,但不忽略 aatxt
      a?.txt
      • **:匹配任意数量的字符,包括路径分隔符。可用于匹配子目录和嵌套目录。

      示例:

      复制代码
      # 忽略所有的 .txt 文件,无论它们在哪个目录下
      **/*.txt
      # 从当前目录出发,忽略a目录下的.jpg(不含嵌套)
      /a/*.jpg
      # 从当前目录出发,忽略a目录下的所有.jpg(含嵌套)
      /a/**/*.jpg
    • 斜杠 /:用于指定匹配相对于 .gitignore 文件所在位置的路径。

    示例:

    复制代码
    # 忽略当前目录下的 notes.txt 文件
    /notes.txt
  3. 注释:

    • 使用 # 标记注释行,注释行将被忽略。

    示例:

    复制代码
    # 这是一个注释
  4. 反转规则:使用 ! 前缀。如果规则以 ! 开头,则表示不忽略匹配的文件或目录。(一般用于保留之前已经匹配忽略的文件或目录)

    示例:

    复制代码
    # 忽略所有 .txt 文件,但不忽略 important.txt
    *.txt
    !important.txt

    此实例表示忽略upload 目录下的所有文件,但是我们此时想要保留该目录,所有可以指定一个文件 .gitkeep,然后保留该目录下的 .gitkeep 文件,也就是保留了该目录。

  5. 行尾斜杠 /:如果规则以 / 结尾,则该规则将匹配目录而非文件。

    示例:

    复制代码
    # 忽略整个 logs 目录
    logs/
  6. 递归通配符 **:递归地匹配任意路径段,包括子目录和嵌套目录,例如 /dir/**/*.txt

    示例:

    复制代码
    # 忽略 dir 目录及其子目录下的所有 .txt 文件
    /dir/**/*.txt
  7. 忽略空目录:.gitignore 文件本身无法忽略空目录,因为 Git 不跟踪空目录。但你可以在目录中创建一个 .gitkeep 文件,使 Git 跟踪该目录。

    示例:

    复制代码
    # 忽略空目录
    /emptydir/.gitkeep

请注意,.gitignore 规则基于模式匹配,并且相对于 .gitignore 文件的位置。

参考 Git 官方文档以获取更多信息:https://git-scm.com/docs/gitignore

相关推荐
荣光波比28 分钟前
Nginx 实战系列(七)—— Nginx一键安装脚本详解
运维·nginx·自动化·云计算
努力学习的小廉38 分钟前
深入了解linux系统—— 线程同步
linux·服务器·数据库·算法
sinat_602035361 小时前
模块与包的导入
运维·服务器·开发语言·python
鲸屿1951 小时前
Ansible之playbook
服务器·网络·ansible
2301_810154551 小时前
VM中CentOS 7密码重置
linux·运维·centos
zhaqonianzhu1 小时前
Linux GPIO 使用 Pinctrl 及 Gpiolib 通俗详解
linux·安卓
网硕互联的小客服1 小时前
408 Request Timeout:请求超时,服务器等待客户端发送请求的时间过长。
运维·服务器
王伯安呢1 小时前
告别线缆束缚!AirDroid Cast 多端投屏,让分享更自由
运维·服务器·教程·投屏·airdroid cast·多端互投
逍遥浪子~1 小时前
搭建本地gitea服务器
运维·服务器·gitea
骄傲的心别枯萎1 小时前
RV1126 NO.16:通过多线程同时获取H264和H265码流
linux·c++·音视频·rv1126