git如何忽略不想要的文件(五)

了解如何通过.gitignore文件高效管理Git仓库中的未跟踪文件,掌握忽略规则的规范,以及如何针对性地忽略特定文件。

一般我们总会有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。 通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。 在这种情况下,我们可以创建一个名为 .gitignore 的文件,列出要忽略的文件。

一、git忽略文件

在工作目录新建一个 .gitignore 文件。这个文件也需要纳入Git管理。Git会读取这个文件,进行忽略。文件名称是Git的约定,必须使用这个名称。
windows系统使用记事本的 文件另存为 可以创建它。并执行 git add .gitignore 命令加入版本控制,执行git status 查看文件状态。

$ git add .gitignore

$ git status
On branch master
No commits yet

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)
        new file:   .gitignore

Untracked files:
  (use "git add <file>..." to include in what will be committed)
        hello.txt

此时,hello.txt是新建的文件,处于未追踪状态。我们此时要让Git忽略它。应该怎么做呢?
应该将其文件名加入到 .gitignore 文件,并保存。
git忽略文件
此时,执行 git status 命令,查看文件状态。

$ git status
On branch master
No commits yet

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)
        new file:   .gitignore

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:   .gitignore

可以看到没有了,未追踪文件(Untracked files): hello.txt
如果此时,删除 .gitignore 中的内容,查看文件状态,它又会出现的。

二、gitignore内容规范

.gitignore 一行定义一个忽略规则,使用glob 模式,它是 shell 所使用的简化了的正则表达式。
下面是部分元字符。

    • 匹配零个或多个任意字符;
  1. ? 匹配任意一个字符;
  2. [] 匹配任何一个列在方括号中的字符 ([abc]要么匹配一个 a,要么匹配一个 b,要么匹配一个 c),如果在方括号中使用短划线分隔两个字符, 表示所有在这两个字符范围内的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的数字)。
  3. ** 两个星号表示匹配任意中间目录
  4. [^] 不匹配方括号中的任意字符。如[^abc],不匹配a、b、c
  5. 忽略文件中的空行或以井号(#)开始的行。#号开头的行是注释。
  6. 如果名称的最前面是一个路径分隔符(/),表示要忽略当前目录下的该文件,而其他子目录中的该文件不忽略。
  7. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是任何目录下所有的此文件或目录。
# 忽略所有的 .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

一般情况下,一个仓库只有根目录下有一个 .gitignore 文件,它应用到整个仓库中。 然而,子目录下也可以有额外的 .gitignore 文件。子目录中的 .gitignore 文件中的规则只作用于它所在的目录中。

GitHub 有一个十分详细的针对数十种项目及语言的 .gitignore 文件列表, 可以在https://github.com/github/gitignore 找到它。

### 创建和配置 `.gitignore` 文件 要在 Git忽略特定文件文件类型,可以通过创建 `.gitignore` 文件并添加相应的规则来实现。`.gitignore` 文件通常位于项目根目录下,并且可以递归地影响所有子目录。 #### 忽略单个文件 如果需要忽略某个具体的文件,比如 `file_01.txt` 或 `file_02.txt`,可以在 `.gitignore` 文件中直接列出这些文件名: ``` file_01.txt file_02.txt ``` 这样,Git 将不再跟踪这些文件的变化[^3]。 #### 忽略某种类型的文件 若希望忽略某一类文件(例如所有 `.log` 文件),可以使用通配符 `*` 来匹配多个文件。例如,在 `.gitignore` 文件中添加以下内容以忽略所有 `.log` 文件: ``` *.log ``` 这将确保 Git 不会追踪任何扩展名为 `.log` 的文件[^5]。 #### 忽略特定目录下的文件 对于特定目录中的文件,如 `model/library/pubspec.lock`,可以指定路径进行忽略: ``` model/library/pubspec.lock ``` 或者,如果想忽略所有子目录下的 `pubspec.lock` 文件,可以使用通配符 `**/` 来表示任意层级的目录: ``` **/pubspec.lock ``` 此规则将应用于整个项目的任何位置出现的 `pubspec.lock` 文件[^4]。 ### 更新已提交文件的状态 如果你已经提交了某些文件到仓库,但后来决定要将其加入 `.gitignore`,你需要从 Git 的追踪记录中移除它们。为此,可以使用 `git rm --cached` 命令。例如,要移除一个特定的 `pubspec.lock` 文件而不删除本地副本,执行: ```bash git rm --cached model/library/pubspec.lock ``` 若需一次性移除所有 `pubspec.lock` 文件,则可以使用通配符: ```bash git rm --cached **/pubspec.lock ``` 完成上述操作后,再次提交更改: ```bash git commit -m "Remove tracked pubspec.lock files according to .gitignore" ``` 此时,这些文件应该不会再出现在 `git status` 的修改列表中[^4]。 ### 删除缓存并重新添加文件 有时,为了使新的 `.gitignore` 规则生效,可能需要先清除 Git 的缓存。可以通过以下命令来实现: ```bash git rm -r --cached . git add . git commit -m 'update .gitignore' ``` 这段代码首先删除了所有已被追踪的文件,然后重新添加所有未被 `.gitignore` 排除的文件,并提交更改。这样做有助于确保 `.gitignore` 中的新规则能够正确应用到整个项目中[^1]。 ### 示例 `.gitignore` 文件 下面是一个简单的 `.gitignore` 文件示例,它包含了常见的几种忽略规则: ``` # 忽略所有.log文件 *.log # 忽略特定文件 file_01.txt file_02.txt # 忽略特定目录下的文件 model/library/pubspec.lock # 忽略所有子目录下的.pub文件 **/*.pub ``` 通过这种方式,你可以根据自己的需求定制 `.gitignore` 文件,从而控制哪些文件文件夹应当被 Git 跟踪,哪些不应当[^2]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值