通常咱們總會有些文件無需歸入 Git 的管理,也不但願它們總出如今未跟蹤文件列表。一般都是些自動生成的文件,像是日誌或者編譯過程當中建立的等等。咱們能夠建立一個名爲 .gitignore
的文件,列出要忽略的文件模式,來看一個簡單的例子:git
$ cat .gitignore *.[oa] *~
第一行告訴 Git 忽略全部以 .o 或 .a 結尾的文件。通常這類對象文件和存檔文件都是編譯過程當中出現的,咱們用不着跟蹤它們的版本。第二行告訴 Git 忽略全部以波浪符(~)結尾的文件,許多文本編輯軟件(好比 Emacs)都用這樣的文件名保存副本。此外,你可能還須要忽略 log,tmp 或者 pid 目錄,以及自動生成的文檔等等。要養成一開始就設置好 .gitignore
文件的習慣,以避免未來誤提交這類無用的文件。正則表達式
文件 .gitignore
的格式規範以下:shell
全部空行或者以註釋符號 # 開頭的行都會被 Git 忽略。ui
可使用標準的 glob 模式匹配。spa
匹配模式最後跟反斜槓(/)說明要忽略的是目錄。日誌
要忽略指定模式之外的文件或目錄,能夠在模式前加上驚歎號(!)取反。code
所謂的 glob 模式是指 shell 所使用的簡化了的正則表達式。星號(*)匹配零個或多個任意字符;[abc] 匹配任何一個列在方括號中的字符(這個例子要麼匹配一個 a,要麼匹配一個 b,要麼匹配一個 c);問號(?)只匹配一個任意字符;若是在方括號中使用短劃線分隔兩個字符,表示全部在這兩個字符範圍內的均可以匹配(好比 [0-9] 表示匹配全部 0 到 9 的數字)。orm
咱們再看一個 .gitignore
文件的例子:server
# 此爲註釋 – 將被 Git 忽略 *.a # 忽略全部 .a 結尾的文件 !lib.a # 但 lib.a 除外 /TODO # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO build/ # 忽略 build/ 目錄下的全部文件 doc/*.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt