Github使用.gitignore文件忽略不必要上傳的文件
(1).gitignore介紹
在工程實現過程中,會生成一些中間文件,或者在項目中的部分文件是不需要進行版本管理的。對於這些文件應該對於Github來講是透明的。Github提供這種功能,可以自己指定哪些文件可以不被管理。具體方法是在版本管理的根目錄下(與.git文件夾同級)創建一個 .gitignore(gitignore是隱藏文件,所以前面有個點){在進行協作開發代碼管理的過程中,常常會遇到某些臨時文件、配置文件、或者生成文件等,這些文件由於不同的開發端會不一樣,如果使用git add . 將所有文件納入git庫中,那麼會出現頻繁的改動和push,這樣會引起開發上的不便。Git可以很方便的幫助我們解決這個問題,那就是建立項目文件過濾規則。Git可以很方便的幫助我們解決這個問題,那就是建立項目文件過濾規則。git中提供兩種過濾機制,一種是全局過濾機制,即對所有的git都適用;另一種是針對某個項目使用的過濾規則。個人傾向於第二種。以我的一個項目為例,該項目用.net開發,.config文件、包括生成的bin/Debug, bin/Release文件等,
我希望不加入git管理。
在代碼目錄下建立.gitignore文件:vim .gitignore ,內容如下:
[plain] view plaincopy
#過濾資料庫文件、sln解決方案文件、配置文件
*.mdb
*.ldb
*.sln
*.config
#過濾文件夾Debug,Release,obj
Debug/
Release/
obj/
然後調用git add. ,執行 git commit即可。
}
方式一:
首先要強調一點,這個文件的完整文件名就是「.gitignore」,注意最前面有個「.」。這樣沒有擴展名的文件在Windows下不太好創建,這裡給出win7的創建方法:
創建一個文件,文件名為:「.gitignore.」,注意前後都有一個點。保存之後系統會自動重命名為「.gitignore」。
一般來說每個Git項目中都需要一個「.gitignore」文件,這個文件的作用就是告訴Git哪些文件不需要添加到版本管理中。
實際項目中,很多文件都是不需要版本管理的,比如Python的.pyc文件和一些包含密碼的配置文件等等。
這個文件的內容是一些規則,Git會根據這些規則來判斷是否將文件添加到版本控制中。
下面我們看看常用的規則:
- /mtk/ 過濾整個文件夾
- *.zip 過濾所有.zip文件
- /mtk/do.c 過濾某個具體文件
很簡單吧,被過濾掉的文件就不會出現在你的GitHub庫中了,當然本地庫中還有,只是push的時候不會上傳。
需要注意的是,gitignore還可以指定要將哪些文件添加到版本管理中:
- !*.zip
- !/mtk/one.txt
唯一的區別就是規則開頭多了一個感嘆號,Git會將滿足這類規則的文件添加到版本管理中。
為什麼要有兩種規則呢?想像一個場景:我們只需要管理/mtk/目錄中的one.txt文件,這個目錄中的其他文件都不需要管理。那麼我們就需要使用:
- /mtk/
- !/mtk/one.txt
假設我們只有過濾規則沒有添加規則,那麼我們就需要把/mtk/目錄下除了one.txt以外的所有文件都寫出來!
最後需要強調的一點是,如果你不慎在創建.gitignore文件之前就push了項目,那麼即使你在.gitignore文件中寫入新的過濾規則,這些規則也不會起作用,Git仍然會對所有文件進行版本管理。
簡單來說,出現這種問題的原因就是Git已經開始管理這些文件了,所以你無法再通過過濾規則過濾它們。
所以大家一定要養成在項目開始就創建.gitignore文件的習慣,否則一旦push,處理起來會非常麻煩。
方式二:
就是新建.gitignore然後再裡面聲明要忽略的文件夾或者文件就可以了,不過麻煩又來了,因為是點開頭,沒有文件名,沒辦法直接在windows目錄下直接創建,必須通過右鍵Git Bash,按照linux的方式來新建.gitignore文件。具體步驟如下:
1. 在需要創建 .gitignore 文件的文件夾, 右鍵選擇
Git Bash 進入命令行,進入項目所在目錄。
2. 輸入 touch .gitignore 在文件夾就生成了一個「.gitignore」文件。
然後在」.gitignore」 文件里輸入你要忽略的文件夾及其文件就可以了。
3.然後用編輯器打開這個文件進行編輯就行了。如果你很牛,熟悉linux下的vi編輯的命令,也可以用命令來聲明規則額。在這裡就不說了額,
附: vi編輯器的怎麼換行呢?
總結:vi保存退出命令x和wq的區別
搜集:不會linux下vi命令,傷不起啊
4.然後就寫規則來操作要忽略的文件了。.gitignore文件過濾有兩種模式,開放模式和保守模式
4.1開放模式負責設置過濾哪些文件和文件夾
eg:
過濾文件夾設置:
/mtk/ 表示過濾這個文件夾
過濾文件設置
指定過濾某種類型的文件:
*.zip
*.rar
*.via
*.tmp
*.err
指定過濾某個文件:
/mtk/do.c
/mtk/if.h
4.2 b保守模式負責設置哪些文件不被過濾,也就是哪些文件要被跟蹤。
跟蹤某個文件夾
!/plutommi/mmi
跟蹤某類文件
!*.c
!*.h
跟蹤某個指定文件
!/plutommi/mmi/mmi_features.h
4.3.配置.gitignore 的簡易原則
採用共享模式與保守模式結合配置的辦法。eg:一個文件夾下有很多文件夾和文件,而我只想跟蹤其中的一個文件,這樣設置就可以滿足這種情況,先用共享模式把整個目錄 都設置為不跟蹤,然後再用保守模式把這個文件夾中想要跟蹤的文件設置為被跟蹤,配置很簡單,就可以跟蹤想要跟蹤的文件。
方式三:
.gitignore 配置文件用於配置不需要加入版本管理的文件,配置好該文件可以為我們的版本管理帶來很大的便利,以下是個人對於配置 .gitignore 的一些心得。
1、配置語法:
以斜杠「/」開頭表示目錄;
以星號「*」通配多個字元;
以問號「?」通配單個字元
以方括弧「[]」包含單個字元的匹配列表;
以嘆號「!」表示不忽略(跟蹤)匹配到的文件或目錄;
此外,git 對於 .ignore 配置文件是按行從上到下進行規則匹配的,意味著如果前面的規則匹配的範圍更大,則後面的規則將不會生效;
2、示例:
(1)規則:fd1/*
說明:忽略目錄 fd1 下的全部內容;注意,不管是根目錄下的 /fd1/ 目錄,還是某個子目錄 /child/fd1/ 目錄,都會被忽略;
(2)規則:/fd1/*
說明:忽略根目錄下的 /fd1/ 目錄的全部內容;
(3)規則:
/*
!.gitignore
!/fw/bin/
!/fw/sf/
說明:忽略全部內容,但是不忽略 .gitignore 文件、根目錄下的 /fw/bin/ 和 /fw/sf/ 目錄;
方式四:
- # cat .gitignore
- *.[oa]
- *~
第一行告訴 Git 忽略所有以 .o 或 .a 結尾的文件。一般這類對象文件和存檔文件都是編譯過程中出現的,我們用不著跟蹤它們的版本。第二行告訴 Git 忽略所有以波浪符(~)結尾的文件,許多文本編輯軟體(比如 Emacs)都用這樣的文件名保存副本。此外,你可能還需要忽略 log,tmp 或者 pid 目錄,以及自動生成的文檔等等。要養成一開始就設置好 .gitignore 文件的習慣,以免將來誤提交這類無用的文件。
文件 .gitignore 的格式規範如下:
- 所有空行或者以注釋符號 # 開頭的行都會被 Git 忽略。
- 可以使用標準的 glob 模式匹配。
- 匹配模式最後跟反斜杠(/)說明要忽略的是目錄。
- 要忽略指定模式以外的文件或目錄,可以在模式前加上驚嘆號(!)取反。
所謂的 glob 模式是指 shell 所使用的、簡化了的正則表達式。星號(*)匹配零個或多個任意字元;[abc] 匹配任何一個列在方括弧中的字元(這個例子要麼匹配一個 a,要麼匹配一個 b,要麼匹配一個 c);問號(?)只匹配一個任意字元;如果在方括弧中使用短劃線分隔兩個字元,表示所有在這兩個字元範圍內的都可以匹配(比如 [0-9] 表示匹配所有 0 到 9 的數字)。
我們再看一個 .gitignore 文件的例子:
- # 忽略所有 .a 結尾的文件
- *.a
- # 但 lib.a 除外
- !lib.a
- # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
- /TODO
- # 忽略 build/ 目錄下的所有文件
- build/
- # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt
- doc/*.txt
其他信息可以直接 man gitignore 查看。
※GPU渲染之OpenGL的GPU管線
※android 結合源碼深入剖析AsyncTask機制原理
TAG:程序員小新人學習 |