git經常使用操做

一、 定義Git全局的 .gitignore 文件
git config --global core.excludesfile ~/.gitignore
#               表示此爲註釋,將被Git忽略
*.a             表示忽略全部 .a 結尾的文件
!lib.a          表示但lib.a除外
/TODO           表示僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
build/          表示忽略 build/目錄下的全部文件,過濾整個build文件夾;
doc/*.txt       表示會忽略doc/notes.txt但不包括 doc/server/arch.txt
 
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 文件
 
/mtk/           表示過濾整個文件夾
*.zip           表示過濾全部.zip文件
/mtk/do.c       表示過濾某個具體文件
 
被過濾掉的文件就不會出如今git倉庫中(gitlab或github)了,固然本地庫中還有,只是push的時候不會上傳。
 
須要注意的是,gitignore還能夠指定要將哪些文件添加到版本管理中,以下:
!*.zip
!/mtk/one.txt
 
惟一的區別就是規則開頭多了一個感嘆號,Git會將知足這類規則的文件添加到版本管理中。爲何要有兩種規則呢?
想象一個場景:假如咱們只須要管理/mtk/目錄中的one.txt文件,這個目錄中的其餘文件都不須要管理,那麼.gitignore規則應寫爲::
/mtk/*
!/mtk/one.txt
 
假設咱們只有過濾規則,而沒有添加規則,那麼咱們就須要把/mtk/目錄下除了one.txt之外的全部文件都寫出來!
注意上面的/mtk/*不能寫爲/mtk/,不然父目錄被前面的規則排除掉了,one.txt文件雖然加了!過濾規則,也不會生效!
 
----------------------------------------------------------------------------------
還有一些規則以下:
fd1/*
說明:忽略目錄 fd1 下的所有內容;注意,無論是根目錄下的 /fd1/ 目錄,仍是某個子目錄 /child/fd1/ 目錄,都會被忽略;
 
/fd1/*
說明:忽略根目錄下的 /fd1/ 目錄的所有內容;
 
/*
!.gitignore
!/fw/ 
/fw/*
!/fw/bin/
!/fw/sf/
說明:忽略所有內容,可是不忽略 .gitignore 文件、根目錄下的 /fw/bin/ 和 /fw/sf/ 目錄;注意要先對bin/的父目錄使用!規則,使其不被排除。
  • 舒適提示:php

    若是你不慎在建立.gitignore文件以前就push了項目,那麼即便你在.gitignore文件中寫入新的過濾規則,這些規則也不會起做用,Git仍然會對全部文件進行版本管理。簡單來講出現這種問題的緣由就是Git已經開始管理這些文件了,因此你沒法再經過過濾規則過濾它們。因此你們必定要養成在項目開始就建立.gitignore文件的習慣,不然一單push,處理起來會很是麻煩。git

相關文章
相關標籤/搜索