Git命令git update-index --assume-unchanged,忽略不想提交的文件(忽略跟蹤)

場景php

咱們在本身的私有測試分支上調試項目邏輯,給文件作了一些特定的修改,可是文件不想被git提交,不想執行git status命令時出如今modified列表裏;再好比,咱們本地的數據庫和測試環境的數據庫配置是不同的,可是在項目開發中每次提交過程當中忽略數據庫配置文件。那麼你這裏就能夠把不想提交的文件忽略。git

固然關於git忽略文件的方式有不少,我這裏使用的是git update-index --assume-unchanged命令。數據庫

代碼舉例測試

D:\code\sp_edaijia (dev/wangteng/test_20181130 -> origin)
git status //私有分支修改過兩個文件,而後執行git status 命令 On branch dev/wangteng/test_20181130 Your branch is up to date with 'origin/dev/wangteng/test_20181130'. Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git checkout -- <file>..." to discard changes in working directory) modified: sp_edaijia/protected/controllers/ApiController.php //文件① modified: sp_edaijia/protected/vendors/ApikeyConfigService.php //文件②

執行忽略命令,注意文件的路徑,不然會報錯spa

D:\code\sp_edaijia (dev/wangteng/test_20181130 -> origin) git update-index --assume-unchanged sp_edaijia/protected/controllers/ApiController.php //這裏忽略ApiController.php 文件

而後再執行git status 命令查看狀態調試

D:\code\sp_edaijia (dev/wangteng/test_20181130 -> origin) git status On branch dev/wangteng/test_20181130 Your branch is up to date with 'origin/dev/wangteng/test_20181130'. Changes not staged for commit: (use "git add <file>..." to update what will be committed) (use "git checkout -- <file>..." to discard changes in working directory) modified: sp_edaijia/protected/vendors/ApikeyConfigService.php //只有一個文件  no changes added to commit (use "git add" and/or "git commit -a")

OK~忽略完畢~code

恢復跟蹤blog

git update-index --no-assume-unchanged sp_edaijia/protected/controllers/ApiController.php //恢復跟蹤

若是忽略的文件多了,可使用如下命令查看忽略列表開發

git uls-files -v | grep '^h\ '

提取文件路徑,方法以下it

git ls-files -v | grep '^h\ ' | awk '{print $2}'

全部被忽略的文件,取消忽略的方法,以下

git ls-files -v | grep '^h' | awk '{print $2}' |xargs git update-index --no-assume-unchanged 
相關文章
相關標籤/搜索