git --ingore 文件理解

在 .gitignore 文件中,每一行的忽略規則的語法如下:


空格不匹配任意文件,可作爲分隔符,可用反斜槓轉義
# 開頭的模式標識註釋,可以使用反斜槓進行轉義
! 開頭的模式標識否定,該文件將會再次被包含,如果排除了該文件的父級目錄,則使用 ! 也不會再次被包含。可以使用反斜槓進行轉義
/ 結束的模式只匹配文件夾以及在該文件夾路徑下的內容,但是不匹配該文件
/ 開始的模式匹配項目跟目錄
如果一個模式不包含斜槓,則它匹配相對於當前 .gitignore 文件路徑的內容,如果該模式不在 .gitignore 文件中,則相對於項目根目錄
**匹配多級目錄,可在開始,中間,結束
?通用匹配單個字符
[]通用匹配單個字符列表
常用匹配示例:
bin/: 忽略當前路徑下的bin文件夾,該文件夾下的所有內容都會被忽略,不忽略 bin 文件
/bin: 忽略根目錄下的bin文件
/*.c: 忽略 cat.c,不忽略 build/cat.c
debug/*.obj: 忽略 debug/io.obj,不忽略 debug/common/io.obj 和 tools/debug/io.obj
**/foo: 忽略/foo, a/foo, a/b/foo等
a/**/b: 忽略a/b, a/x/b, a/x/y/b等
!/bin/run.sh: 不忽略 bin 目錄下的 run.sh 文件
*.log: 忽略所有 .log 文件
config.php: 忽略當前路徑的 config.php 文件
.gitignore規則不生效
.gitignore只能忽略那些原來沒有被track的文件,如果某些文件已經被納入了版本管理中,則修改.gitignore是無效的。

忽略未被check的文件,將文件從本地緩存中刪除,改變爲未track的狀態,然後可以繼續提交

git rm -r --cached .
git add .
git commit -m 'update .gitignore'
規則 作用
/mtk 過濾整個文件夾
*.zip 過濾所有.zip文件
/mtk/do.c 過濾某個具體文件
!/mtk/one.txt 追蹤(不過濾)某個具體文件
注意:如果你創建.gitignore文件之前就push了某一文件,那麼即使你在.gitignore文件中寫入過濾該文件的規則,該規則也不會起作用,git仍然會對該文件進行版本管理。

配置語法
以斜槓“/”開頭表示目錄;
以星號“*”通配多個字符;
以問號“?”通配單個字符
以方括號“[]”包含單個字符的匹配列表;
以歎號“!”表示不忽略(跟蹤)匹配到的文件或目錄。
注意: git 對於 .gitignore配置文件是按行從上到下進行規則匹配的

指定對應的ingore文件進行配置和讀取


這種方式也需要創建相應的 .gitignore 文件,可以放在任意位置。然後在使用以下命令配置Git:

git config --global core.excludesfile ~/.gitignore

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章