gitignore文件可以用來忽略某些不需要放在git里的文件,但是經常我們在gitignore里寫了忽略語句,但是不生效
原因1. 語法錯誤,解決方案:再次檢查語法是否寫的正確, 部分語法參照下面
- 空格不匹配任意文件,可作為分隔符,可用反斜杠轉義
- 開頭的文件標識注釋,可以使用反斜杠進行轉義
- ! 開頭的模式標識否定,該文件將會再次被包含,如果排除了該文件的父級目錄,則使用 ! 也不會再次被包含。可以使用反斜杠進行轉義
- / 結束的模式只匹配文件夾以及在該文件夾路徑下的內容,但是不匹配該文件
- / 開始的模式匹配項目跟目錄
- 如果一個模式不包含斜杠,則它匹配相對於當前 .gitignore 文件路徑的內容,如果該模式不在 .gitignore 文件中,則相對於項目根目錄
- ** 匹配多級目錄,可在開始,中間,結束
- ? 通用匹配單個字符
- [] 通用匹配單個字符列表
常用匹配示例:
- 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 文件
- test.csproj: 忽略當前路徑的 test.csproj 文件
原因2 緩存 gitignore只能忽略那些原來沒有被track的文件,如果某些文件已經被納入了版本管理中,則修改.gitignore是無效的. 解決方案: 清理緩存
先后執行 ,記住有點
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
如果你寫的語法沒有錯誤,那么你會在控制台里看到刪除那些忽略文件,如果沒有,那就可能是語法錯誤
