场景
我们在自己的私有测试分支上调试项目逻辑,给文件做了一些特定的修改,但是文件不想被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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。