一、本地仓库操作

1、构建本地仓库

  • 初始化本地仓库,生成.git隐藏文件 
    $ git init
  • 在文件夹内添加readme.md文件,执行如下命令,添加到本地仓库暂存区 
    $ git add readme.md
  • 提交到本地仓库 
    $ git commit -m “add readme.md”

2、添加、提交

  • 修改readme.md文件,查看本地代码的状态(与本地仓库对比) 
    $ git status
    On branch master
    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: readme.md
      no changes added to commit (use "git add" and/or "git commit -a")
  • 查看具体差异 
    $ git diff
    diff --git a/readme.md b/readme.md
    index d1d06ad..a3e18d9 100644
    --- a/readme.md
    +++ b/readme.md
    @@ -1 +1 @@
    -1111
    \ No newline at end of file
    +11112222
    \ No newline at end of file
  • 将本地修改添加到本地仓库 
    $ git add .
  • 查看状态 
    $ git status
    On branch master
    Changes to be committed:
     (use "git reset HEAD <file>..." to unstage)    modified: readme.md
  • 提交修改到本地仓库 
    $ git commit -m “modify readme.md”
    [master 3350af9] modify readme.md
     1 file changed, 1 insertion(+)
  • 再次查看状态,发现已经与本地仓库相同了 
    $ git status
    On branch master
    nothing to commit, working tree clean
  • 删除文件

    第一种,实际上删除也是一种修改,所以可以删除本地文件,然后用上面的add+commit的方式 
    第二种 
    $ git rm readme.md 
    $ git commit -m “delete readme.md”

3.查看日志,回退

  • 查看历史日志
  • $ git log 命令或者 $ git log --pretty=oneline
    27943fdf37d8767bdc87fb496f7c2f006a23b953 (HEAD -> master) modify readme.md
    3350af9b900fd0d1bef70daf3742dc65c9ca4c98 modify readme.md
    ff61e65f4a1c4fc70fd4f313c065ec29c6cf647e add readme.md
  • 回退到上一个版本:HEAD代表当前版本,HEAD^是上一个版本,以此类推;也可以用 commit id 如”ff61e65f4a1c4fc70fd4f313c065ec29c6cf647e”的前几位(能代表唯一性)代替。 
    $ git reset –hard HEAD^
    HEAD is now at 3350af9 modify readme.md
  • 查看文件状态,发现已经回退到上一个版本 
    $ cat readme.md
    1111
  • 再次查看log,发现上一个版本的log已经没了 
    $ git log –pretty=oneline
    3350af9b900fd0d1bef70daf3742dc65c9ca4c98 modify readme.md
    ff61e65f4a1c4fc70fd4f313c065ec29c6cf647e add readme.md
  • 根据commit id再回退到原来的版本,发现修改又回来了 
    $ git reset –hard 27943 
    $ cat readme.md
    11112222

    2323232
  • 查看操作记录,根据操作记录就可以回退到任意版本了 
    $ git reflog
    27943fd HEAD@{0}: reset: moving to 27943
    3350af9 HEAD@{1}: reset: moving to HEAD^
    27943fd HEAD@{2}: commit: modify readme.md
    3350af9 HEAD@{3}: commit: modify readme.md
    ff61e65 HEAD@{4}: commit (initial): add readme.md
  • 将暂存区的修改撤销掉

首先对readme.md进行修改,添加到暂存区 
$ git add readme.md 
$ git status 
$ git reset HEAD readme.md

  • 丢弃工作区的修改 
    $ git checkout – readme.md

二、远程仓库

1、将本地仓库添加到远程仓库

  • 查看本地remote origin是否存在(origin是对远程库的别称) 
    $ git remote -v

  • 如果不存在,则添加 
    $ git remote add origin http://192.168.1.222/wei/Test.git

  • 关联远程分支 
    $ git branch –set-upstream master origin/master

  • 接下来,就可以直接向已有的远程仓库提交代码啦 
    $ git add . 
    $ git commit -m “msg” 
    $ git push

  • 更新origin 
    $ git remote rm origin 
    $ git remote add origin 新地址.git 
    $ git branch –set-upstream master origin/master

  • 查看origin配置,还可以通过查看config文件来查看origin的配置 
    $ vi .git/config

2、从远程仓库克隆到本地仓库

git 简单命令总结的更多相关文章

  1. git -- 简单命令

    1.git init    当前目录初始化   2.git  status  检查当前文件状态   Changes to be committed” 这行下面的,就说明是已暂存状态 Changed b ...

  2. git简单命令

    1. git status(不代参数) -- 查看本地修改过的文件 git status -s (简洁) 2. git add  -- 添加到暂存区 3. git commit -m '提交的mess ...

  3. git相关的简单命令

    初次使用建议看这个ppt:http://www.bootcss.com/p/git-guide/    从现有仓库克隆 这需要用到 git clone 命令.如果你熟悉其他的 VCS 比如 Subve ...

  4. 认识git的简单命令

    一.课程目的 教大家学会it的简单命令(老师建议 English 的前后要加空格) 二.认识 git 命令 整篇文章都是用语雀写的. 解释了(使用git)绑定gitee的操作 https://www. ...

  5. git 常用的简单命令

    git add . 会把当前目录中所有有改动的文件(不包括.gitignore中要忽略的文件)都添加到git缓冲区以待提交 git add * 会把当前目录中所有有改动的文件(包括.gitignore ...

  6. 常用到的简单命令 Sublime Git NPM WindowsCMD MacTerminal(Unix命令) Vim

    sublime 选择标签及其内容 ctrl+shift+a连续按两次 调出Package console: Mac: command + shift + p 安装插件: 1.调出 Package co ...

  7. git简单使用命令

    每次都会忘记git使用命令 在本上做了笔记,网上也备份一份吧 这个是删除步骤: 拉取远程的Repo到本地(如果已经在本地,可以略过) $ git clone xxxxxx 在本地仓库删除文件  $ g ...

  8. git常用的一些简单命令

    1.如果一个文件被修改了,但是还没有使用 git add 命令,此时想取消这次修改,需要执行的命令如下: git checkout -- 文件名 2.如果一个文件执行了 git add ,此时想取消这 ...

  9. GIT笔记命令行(1)

    Git简单易用,只要输入git就可以列出他的所有参数 C:\Users\spu>git usage: git [--version] [--help] [-C <path>] [-c ...

随机推荐

  1. C语言输出格雷码

    格雷码是以n位的二进制来表示数. 与普通的二进制表示不同的是,它要求相邻两个数字只能有1个数位不同. 首尾两个数字也要求只有1位之差. 有很多算法来生成格雷码.以下是较常见的一种: 从编码全0开始生成 ...

  2. Legend 图例

    1.添加图例 >>> import matplotlib.pyplot as plt >>> import numpy as np >>> x = ...

  3. python基础 (编码进阶,文件操作和深浅copy)

    1.编码的进阶 字符串在Python内部的表示是unicode编码,因此,在做编码转换时,通常需要以unicode作为中间编码. 即先将其他编码的字符串解码(decode)成unicode,再从uni ...

  4. arguments.callee的作用及替换方案

    arguments.callee的作用 arguments 的主要用途是保存函数参数, 但这个对象还有一个名叫 callee 的属性,返回正被执行的 Function 对象,也就是所指定的 Funct ...

  5. Sum of Even Numbers After Queries LT985

    We have an array A of integers, and an array queries of queries. For the i-th query val = queries[i] ...

  6. rabbitmq初学之连接测试

    Login was refused using authentication mechanism PLAIN. 用户名或密码没有设置,或者错误

  7. 转载-js如何设置网页横屏和竖屏切换

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  8. Ural 1018 Binary Apple Tree

    题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1018 Dynamic Programming. 首先要根据input建立树形结构,然后在 ...

  9. for循环的实例

    1.大马驮2石粮食,中马驮1石粮食,两头小马驮一石粮食,要用100匹马,驮100石粮食,该如//首先我们要知道一百石粮食需要这些马分别几匹 //第一个是大马,需要五十匹马for(var x=0;x&l ...

  10. sublime将python的运行结果在命令行显示

    sublime将python的运行结果在命令行显示 为什么这么折腾? 因为每次查看输出结果都要上下拖动窗口,很烦. 将build system修改为 { "cmd": [" ...