這個(gè)文件每一行保存了一個(gè)匹配的規(guī)則例如:
# 此為注釋 – 將被 Git 忽略
*.a # 忽略所有 .a 結(jié)尾的文件
!lib.a # 但 lib.a 除外
/TODO # 僅僅忽略項(xiàng)目根目錄下的 TODO 文件宰啦,不包括 subdir/TODO
build/ # 忽略 build/ 目錄下的所有文件
doc/*.txt # 會(huì)忽略 doc/notes.txt 但不包括 doc/server/arch.txt
Git忽略規(guī)則及.gitignore規(guī)則不生效的解決辦法
在git中如果想忽略掉某個(gè)文件,不讓這個(gè)文件提交到版本庫(kù)中田炭,
可以使用修改根目錄中 .gitignore 文件的方法(如無漓柑,則需自己手工建立此文件)。
有時(shí)候在項(xiàng)目開發(fā)過程中栋豫,突然心血來潮想把某些目錄或文件加入忽略規(guī)則谚殊,按照上述方法定義后發(fā)現(xiàn)并未生效
原因是.gitignore只能忽略那些 原來沒有 被track(納入了版本管理)的文件嫩絮,如果某些文件已經(jīng)被納入了版本管理中围肥,則修改.gitignore是無效的穆刻。
那么解決方法就是先把本地緩存刪除(改變成未track狀態(tài)),然后再提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
注意:
不要誤解了 .gitignore 文件的用途榜轿,該文件只能作用于 Untracked Files,也就是那些從來沒有被 Git 記錄過的文件(自添加以后甸私,從未 add 及 commit 過的文件)飞傀。
如果文件曾經(jīng)被 Git 記錄過,那么.gitignore 就對(duì)它們完全無效弃鸦。