Github Pls Forget Me —— .gitignore詳解

忽略某些文件

通常咱們總會有些文件無需歸入 Git 的管理,也不但願它們總出如今未跟蹤文件列表。一般都是些自動生成的文件,好比日誌文件,或者編譯過程當中建立的臨時文件等。咱們能夠建立一個名爲 .gitignore 的文件,列出要忽略的文件模式。來看一個實際的例子:git

$ cat .gitignore
    *.[oa]
    *~

第一行告訴 Git 忽略全部以 .o 或 .a 結尾的文件。通常這類對象文件和存檔文件都是編譯過程當中出現的,咱們用不着跟蹤它們的版本。第二行告訴 Git 忽略全部以波浪符(~)結尾的文件,許多文本編輯軟件(好比 Emacs)都用這樣的文件名保存副本。此外,你可能還須要忽略 log,tmp 或者 pid 目錄,以及自動生成的文檔等等。要養成一開始就設置好 .gitignore 文件的習慣,以避免未來誤提交這類無用的文件。正則表達式

文件 .gitignore 的格式規範以下:shell

  • 全部空行或者以註釋符號 # 開頭的行都會被 Git 忽略。ui

  • 可使用標準的 glob 模式匹配。spa

  • 匹配模式最後跟反斜槓(/)說明要忽略的是目錄。.net

  • 要忽略指定模式之外的文件或目錄,能夠在模式前加上驚歎號(!)取反。日誌

  • 所謂的 glob 模式是指 shell 所使用的簡化了的正則表達式。星號(*)匹配零個或多個任意字符;[abc] 匹配任何一個列在方括號中的字符(這個例子要麼匹配一個 a,要麼匹配一個 b,要麼匹配一個 c);問號(?)只匹配一個任意字符;若是在方括號中使用短劃線分隔兩個字符,表示全部在這兩個字符範圍內的均可以匹配(好比 [0-9] 表示匹配全部 0 到 9 的數字)。code

咱們再看一個 .gitignore 文件的例子:server

# 此爲註釋 – 將被 Git 忽略
    # 忽略全部 .a 結尾的文件
    *.a
    # 但 lib.a 除外
    !lib.a
    # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
    /TODO
    # 忽略 build/ 目錄下的全部文件
    build/
    # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt
    doc/*.txt
    # 會忽略掉 doc/ 裏面全部的txt文件,包括子目錄下的(**/ 從 Git 1.8.2 以後開始支持 **/ 匹配模式,表示遞歸匹配子目錄下的文件)
    doc/**/*.txt

更多Git的知識請猛點這裏對象

相關文章
相關標籤/搜索