略微加速

略速 - 互联网笔记

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

2021-08-05 leiting (181阅读)

标签 Git

场景

我们在自己的私有测试分支上调试项目逻辑,给文件做了一些特定的修改,但是文件不想被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 ls-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  

 

北京半月雨文化科技有限公司.版权所有 京ICP备12026184号-3