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

OldBoy~發表於2018-11-23

場景

我們在自己的私有測試分支上除錯專案邏輯,給檔案做了一些特定的修改,但是檔案不想被git提交,不想執行git status命令時出現在modified列表裡;再比如,我們本地的資料庫和測試環境的資料庫配置是不一樣的,但是在專案開發中每次提交過程中忽略資料庫配置檔案。那麼你這裡就可以把不想提交的檔案忽略。

當然關於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 //檔案②

執行忽略命令,注意檔案的路徑,否則會報錯

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~忽略完畢~

恢復跟蹤

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

如果忽略的檔案多了,可以使用以下命令檢視忽略列表

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

提取檔案路徑,方法如下

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  

 

相關文章