在git中如果想忽略掉某個文件,不讓這個文件提交到版本庫中,可以使用修改根目錄中 .gitignore 文件的方法(如無率翅,則需自己手工建立此文件)凝赛。這個文件每一行保存了一個匹配的規(guī)則例如:
“#”此為注釋 – 將被 Git 忽略
.a # 忽略所有 .a 結尾的文件
!lib.a # 但 lib.a 除外
/TODO # 僅僅忽略項目根目錄下的 TODO 文件袍冷,不包括 subdir/TODO
build/ # 忽略 build/ 目錄下的所有文件
doc/.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt
規(guī)則很簡單栈戳,不做過多解釋,但是有時候在項目開發(fā)過程中难裆,突然心血來潮想把某些目錄或文件加入忽略規(guī)則,按照上述方法定義后發(fā)現(xiàn)并未生效镊掖,原因是.gitignore只能忽略那些原來沒有被track的文件乃戈,如果某些文件已經被納入了版本管理中,則修改.gitignore是無效的亩进。那么解決方法就是先把本地緩存刪除(改變成未track狀態(tài))症虑,然后再提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
注意:
不要誤解了 .gitignore 文件的用途,該文件只能作用于 Untracked Files归薛,也就是那些從來沒有被 Git 記錄過的文件(自添加以后谍憔,從未 add 及 commit 過的文件)。
如果文件曾經被 Git 記錄過主籍,那么.gitignore 就對它們完全無效习贫。
例子:
- .gitignore內容為空,創(chuàng)建a.py文件千元,執(zhí)行 git add 和git commit git push命令
- 修改.gitignore內容為*.yy苫昌,并 git add 和git commit git push命令
- 修改a.py文件,git status后幸海,文件顯示修改祟身,執(zhí)行git add 和git commit git push后,查看遠程倉庫的a.py物独,是修改后的內容
如果想讓a.py文件的更新不更新到遠程倉庫袜硫,執(zhí)行命令 - git rm -r --cached /Users/fujunmin/files/python/selfPractise/Test_framework/a.yy
- git commit -m 'delete a.yy'
3.git push
至此,查看遠程倉庫挡篓,已經沒有a.yy文件了