gitignore檔案詳解

2021-08-15 14:49:39 字數 3044 閱讀 4588

配置語法:

以斜槓「/」開頭表示目錄;

以星號「*」通配多個字元;

以問號「?」通配單個字元

以方括號「」包含單個字元的匹配列表;

以嘆號「!」表示不忽略(跟蹤)匹配到的檔案或目錄;

此外,git 對於 .ignore 配置檔案是按行從上到下進行規則匹配的,意味著如果前面的規則匹配的範圍更大,則後面的規則將不會生效;

2、示例:

(1)規則:fd1/* 

說明:忽略目錄 fd1 下的全部內容;注意,不管是根目錄下的 /fd1/ 目錄,還是某個子目錄 /child/fd1/ 目錄,都會被忽略;

(2)規則:/fd1/* 

說明:忽略根目錄下的 /fd1/ 目錄的全部內容;

(3)規則:

/*

!.gitignore

!/fw/bin/

!/fw/sf/

說明:忽略全部內容,但是不忽略 .gitignore 檔案、根目錄下的 /fw/bin/ 和 /fw/sf/ 目錄

有三種方法可以實現過濾掉git裡不想上傳的檔案,這三種方法都能達到目的,只不過適用情景不一樣。

1)第一種方法

針對單一工程排除檔案,這種方式會讓這個工程的所有修改者在轉殖**的同時,也能轉殖到過濾規則,而不用自己再寫乙份,這就能保證所有修改者應用的都是同乙份規則,而不是張三自己有一套過濾規則,李四又使用另一套過濾規則,個人比較喜歡這個。配置步驟如下:

在工程根目錄下建立.gitignore檔案,將要排除的檔案或目錄 寫到.gitignore這個檔案中,其中有兩種寫入方法。

a)使用命令列增加排除檔案 

排除以.class結尾的檔案 echo 「*.class」 >.gitignore (>> 是在檔案尾增加,> 是刪除已經存在的內容再增加),之後會在當前目錄下生成乙個.gitignore的檔案。

排除bin目錄下的檔案 echo 「bin/」 >.gitignore

b)最方便的辦法是,用記事本開啟,增加需要排除的檔案或目錄,一行增加乙個,例如:

1

2

3

4

5

6

*.class

*.apk

bin/

gen/

.settings/

proguard/

2)第二種方法

全域性設定排除檔案,這會在全域性起作用,只要是git管理的工程,在提交時都會自動排除不在控制範圍內的檔案或目錄。這種方法對開發者來說,比較省事,只要一次全域性配置,不用每次建立工程都要配置一遍過濾規則。但是這不保證其他的開發者在轉殖你的**後,他們那邊的規則跟你的是一樣的,這就帶來了**提交過程中的各種衝突問題。

配置步驟如下:

a)像方法(1)一樣,也需要建立乙個.gitignore檔案,把要排除的檔案寫進去。

b)但在這裡,我們不規定一定要把.gitnore檔案放到某個工程下面,而是任何地方,比如我們這裡放到了git預設的home路徑下,比如:/home/wangshibo/hqsb_ios

c)使用命令方式可以配置全域性排除檔案 git config --global core.excludesfile ~/.gitignore,你會發現在~/.gitconfig檔案中會出現excludesfile = /home/wangshibo/hqsb_ios/.gitignore。

說明git把檔案過濾規則應用到了global的規則中。

3)第三種方法

單個工程設定排除檔案,在工程目錄下找到.git/info/exclude,把要排除的檔案寫進去:

1

2

3

4

5

6

*.class

*.apk

bin/

gen/

.settings/

proguard/

這種方法就不提倡了,只能針對單一工程配置,而且還不能將過濾規則同步到其他開發者,跟方法(1)(2)比較起來沒有一點優勢。

------------------------git忽略規則及.gitignore規則不生效的解決辦法-----------------------------

在git中如果想忽略掉某個檔案,不讓這個檔案提交到版本庫中,可以使用修改根目錄中 .gitignore 檔案的方法(如無,則需自己手工建立此檔案)。這個檔案每一行儲存了乙個匹配的規則例如:

# 此為注釋 – 將被 git 忽略

*.a # 忽略所有 .a 結尾的檔案

!lib.a # 但 lib.a 除外

/todo # 僅僅忽略專案根目錄下的 todo 檔案,不包括 subdir/todo

build/ # 忽略 build/ 目錄下的所有檔案

doc/*.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt

規則很簡單,不做過多解釋,但是有時候在專案開發過程中,突然心血來潮想把某些目錄或檔案加入忽略規則,按照上述方法定義後發現並未生效,原因是.gitignore只能忽略那些原來沒有被track的檔案,如果某些檔案已經被納入了版本管理中,則修改.gitignore是無效的。那麼解決方法就是先把本地快取刪除(改變成未track狀態),然後再提交:

git rm -r --cached .

git add .

git commit -m 'update .gitignore'

注意:不要誤解了 .gitignore 檔案的用途,該檔案只能作用於 untracked files,也就是那些從來沒有被 git 記錄過的檔案(自新增以後,從未 add 及 commit 過的檔案)。

如果檔案曾經被 git 記錄過,那麼.gitignore 就對它們完全無效。

gitignore檔案語法

gitignore問卷位置 在專案根目錄下建立乙個名為.gitignore的檔案 注意檔案的前面有個點 用於記錄忽略規則。注 windows下不可以按常規方法新建.gitignore檔案,需要在命令列中進行建立 如 git base下 touch gitignore ignore檔案語法 1 注釋 ...

gitignore忽略檔案

在進行協作開發 管理的過程中,常常會遇到某些臨時檔案 配置檔案 或者生成檔案等,這些檔案由於不同的開發端會不一樣,如果使用git add 將所有檔案納入git庫中,那麼會出現頻繁的改動和push,這樣會引起開發上的不便。git可以很方便的幫助我們解決這個問題,那就是建立專案檔案過濾規則。git中提供...

配置 gitignore檔案

1.新建.gitignore檔案 touch gitignore 2.在.gitignore中加入要忽略的檔案 vim gitignore 檔案中加入以下,儲存退出 idea pycache 具體的還可以在查一下配置規則,在此就不再累述 3.gitignore只能忽略那些原來沒有被track的檔案,...