git自学

学习内容来源Git权威指南,廖雪峰的博客

1 配置git的用户名和邮箱地址:    $ git config --global user.name "zhangwei" 

git config --global user.email 987785932@qq.com

2 git开启颜色显示:git config --global color.ui true

3 本用户配置git的别名: $ git config --global alias.st status  //是把git status命令配置成git st即可使用
4 显示.git 目录所在的位子(前提是在工作的目录下,别的目录下没有用):git rev-parse --git-dir
5 显示工作区根目录:git rev-parse --show-toplevel
6 相对于工作区间根目录胡相对目录:$ git rev-parse --show-prefix
7 显示当前目录(cd)后退(up)到工作区间的根的深度:$ git rev-parse --show-cdup
8 读取和更改INI配置文件的内容:到.git的目录下 $ cat .git/config .得到配置的内容如下
                    [core]
                            repositoryformatversion = 0
                            filemode = true
                            bare = false
                            logallrefupdates = true
9 如果查看INI[core] bare的属性值:  $ git config caor.bare
10 如果想修改INI文件的某个属性值:git config <section>.<key> <value>   
                     eg: $ git config a.b xx
                     会看到INI文件中多了如下内容
                     [a]
                            b = xx
11 用git向任何INI文件中添加配置:
                eg:
                向text.ini添加:
                GIT_CONFIG=test.ini git config a.b.c.d "hello,world",
12 向test.ini读取配置: $ GIT_CONFIG=test.ini git config a.b.c.d      结果:hello,world
13 查看版本库的提交日志:git log --pretty=fuller
14 像welcome.txt文档追加句话   : $ echo "nice" >> welcome.txt
15 看修改后的文件和版本库文件的差异:git diff
16 重置到任意次数提交的方法:
                先用 $ git log --graph --oneline找到要重置的id
                然后 $ git reset --hard <id>即可            
17  查看marster的分支:tail -n .git/logs/refs/heads/master  -n可以自己看最近的几次,4就是最近四次的提交的记录.
18 查看reset的记录,即东西被重置的记录,利用reflog: $ git reflog show master | head -n   -n的意思和上一样            
19 保存进度:git stash  
20 查看之前保存的进度:git stash list

21 恢复进度:git stash pop   这是恢复最近的进度       

我自己玩的git:
1.目录存在于/a/0ps/pets/aweiyo_work_study/leargit(往txt文本中添加内容:cat 你要写入的内容 >> filename.txt 可以写txt文件,新的内容追加到文件末尾)
初始化一个Git仓库,使用git init命令。

创建版本库:
    第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件;
    第二步,使用命令git commit,完成。
查看版本库的改动信息和现在的状态:
    要随时掌握工作区的状态,使用git status命令。
    如果git status告诉你有文件被修改过,用git diff可以查看修改内容,对比之前的内容。
回到之前的版本:
    1.用git log命令显示从最近到最远的提交日志.如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数:
    2.回到对到之前的版本.先通过log找到要回到的id,然后$ git reset --hard id即可.
    3.万能找id.Git提供了一个命令git reflog用来记录你的每一次命令:这个也是可以找到,之前修改版本的id,然后通过执行$ git reset --hard id即可.
git一次性add多个文件:
        git add *.py
    用git status查看,会有提示:
    Changes to be committed:
      (use "git reset HEAD <file>..." to unstage)
        new file:   1.py
        new file:   2.py
        new file:   3.py
        new file:   4.py
    要排除掉其中一个文件,用:
    git reset HEAD 1.py
    这时再用git status看,1.py变成了untracked,剩下的就可以提交了。
管理修改:
撤销修改:
删除文件:
远程仓库:
添加远程仓库:
从远程仓库克隆:
分支的创建和合并:
                查看分支:git branch
                
                创建分支:git branch <name>
                
                切换分支:git checkout <name>
                
                创建+切换分支:git checkout -b <name>
                
                合并某分支到当前分支:git merge <name>
                
                删除分支:git branch -d <name>
                实例:
                首先,我们创建dev分支,然后切换到dev分支:
                $ git checkout -b dev
                Switched to a new branch 'dev'
                
                git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
                $ git branch dev
                $ git checkout dev
                Switched to branch 'dev'
                
                然后,用git branch命令查看当前分支:
                $ git branch
                * dev
                  master
                
                git branch命令会列出所有分支,当前分支前面会标一个*号。
                然后,我们就可以在dev分支上正常提交,比如对readme.txt做个修改,加上一行:
                Creating a new branch is quick.
                
                然后提交:
                $ git add readme.txt
                $ git commit -m "branch test"
                [dev fec145a] branch test
                 1 file changed, 1 insertion(+)
                
                现在,dev分支的工作完成,我们就可以切换回master分支:
                $ git checkout master
                Switched to branch 'master'
                
                切换回master分支后,再查看一个readme.txt文件,刚才添加的内容不见了!因为那个提交是在dev分支上,而master分支此刻的提交点并没有变:
                git-br-on-master
                
                现在,我们把dev分支的工作成果合并到master分支上:
                $ git merge dev
                Updating d17efd8..fec145a
                Fast-forward
                 readme.txt |    1 +
                 1 file changed, 1 insertion(+)
                
                git merge命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。
                注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,所以合并速度非常快。
                当然,也不是每次合并都能Fast-forward,我们后面会将其他方式的合并。
                合并完成后,就可以放心地删除dev分支了:
                $ git branch -d dev
                Deleted branch dev (was fec145a).
                
                删除后,查看branch,就只剩下master分支了:
                $ git branch
                * master
                
                因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。
撤销修改:
                场景1:改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
                场景2:不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
                场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考上面的回到之前的版本,不过前提是没有推送到远程库。
删除文件:
                删除一个文件(彻底不可恢复)1. $ rm test.txt 2.$ git rm test.txt 3.$ git commit -m "remove test.txt"(该文件是已经commit了的,不建议彻底删除!!!!!)
                恢复误删的文件:$ git checkout -- test.txt  这个是只限于刚执行了rm test.txt操作的恢复
远程仓库:
                git push origin master推送最新修改;
                要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。         

                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值