美文网首页
.gitignore

.gitignore

作者: 慧琴如翌 | 来源:发表于2018-04-02 10:38 被阅读7次

    在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:
    “#”此为注释 – 将被 Git 忽略
    .a # 忽略所有 .a 结尾的文件
    !lib.a # 但 lib.a 除外
    /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
    build/ # 忽略 build/ 目录下的所有文件
    doc/
    .txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
    规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:

    git rm -r --cached .
    git add .
    git commit -m 'update .gitignore'

    注意:
    不要误解了 .gitignore 文件的用途,该文件只能作用于 Untracked Files,也就是那些从来没有被 Git 记录过的文件(自添加以后,从未 add 及 commit 过的文件)。
    如果文件曾经被 Git 记录过,那么.gitignore 就对它们完全无效。
    例子:

    1. .gitignore内容为空,创建a.py文件,执行 git add 和git commit git push命令
    2. 修改.gitignore内容为*.yy,并 git add 和git commit git push命令
    3. 修改a.py文件,git status后,文件显示修改,执行git add 和git commit git push后,查看远程仓库的a.py,是修改后的内容
      如果想让a.py文件的更新不更新到远程仓库,执行命令
    4. git rm -r --cached /Users/fujunmin/files/python/selfPractise/Test_framework/a.yy
    5. git commit -m 'delete a.yy'
      3.git push
      至此,查看远程仓库,已经没有a.yy文件了

    原链接:
    https://www.cnblogs.com/kevingrace/p/5690241.html

    相关文章

      网友评论

          本文标题:.gitignore

          本文链接:https://www.haomeiwen.com/subject/piythftx.html