git命令行学习思路总结

Git基本命令操作

A.首先,理解git操作流:

  a.txt.local   ---[add]--->    a.txt(staged)    ---[commit]--->   a.txt.remote

  1.解释上述操作流(本地-服务器):我们可以理解为存在三个阶段:1.本地,2.暂存,3.服务器。也就是说我们把新修改的文件提交到服务器,可以有两种方式:1-2-3,1-3.这两种方式分别对应的操作是a: add+commit ,b: commit -a.

  a.txt.remote ---[commit --amend]---> a.txt(staged)  ---["git reset HEAD <file>..."]--->  a.txt.local(modified) ---["git reset HEAD <file>..."]--->a.txt.local(original)

  2.解释上述取消流(服务器-本地):(1)如果我们提交到服务器,漏掉了几个文件没有加,或者提交信息写错了:commit --amend 会将暂存区提交,然后从新编辑提交信息。(2)如果我们想从staged回到unstaged那么运行git reset HEAD <file>命令,如果嫌弃命令太长可以使用git --global config alias.unstaged ‘reset HEAD‘来重新命名参数,下次直接git unstaged <file>就可以了.(3)如果我们修改了文件想回到未修改时候可以使用git checkout -- <file>.也同样可以使用 git --global config alias.ck ‘checkout --‘,下次直接运行 git ck <file> 就行。

B.其次,远程仓库操作:

  1.取过来

    git remote show 查看本地项目的远程端url情况。

    git clone [url] 从github项目地址中克隆出项目,然后自动跟踪其分支,并且会合并。

    git remote add [shortname] [url] 如果我们通过 git init 初始化一个本地项目,那是没有远端的,通过这个命令可以进行添加并且起名字,或者添加多个远端。

    git fetch [remote-name] 通过不同的远端获取项目,这个fetch来的项目是不会合并的,感觉就像个wget。 

    git remote show [remote-name]  可以通过这个命令查看远端信息情况

  2.给过去

    git push orgin branch-name 我们推送到orgin远端的branch-name分支中。

    git remote rename s1 s2 将本地设置的远端进行重命名s1->s2

    git remote rm s1 删除设置好的本地远端s1

C.最后,我们看附加操作:

  git log 一级参数

        

选项 说明
-p 按补丁格式显示每个更新之间的差异。
--word-diff 按 word diff 格式显示差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。
--oneline --pretty=oneline --abbrev-commit 的简化用法。

  1.查看提交log

     简单介绍两个使用:

     git log -p -2  --word-diff  -p通过比较上次commit的不同,-2是显示最近的两次。--word-diff 则非常简单的显示了单词级别的修改。

     git log --pretty=online 单行显示格式。

     git log --pretty = format:" " ,里面的二级参数如下图,中间加空格就ok,私人定制,非常方便

      

选项 说明
%H 提交对象(commit)的完整哈希字串
%h 提交对象的简短哈希字串
%T 树对象(tree)的完整哈希字串
%t 树对象的简短哈希字串
%P 父对象(parent)的完整哈希字串
%p 父对象的简短哈希字串
%an 作者(author)的名字
%ae 作者的电子邮件地址
%ad 作者修订日期(可以用 -date= 选项定制格式)
%ar 作者修订日期,按多久以前的方式显示
%cn 提交者(committer)的名字
%ce 提交者的电子邮件地址
%cd 提交日期
%cr 提交日期,按多久以前的方式显示
%s 提交说明

  2.操作版本信息

          git tag 用来显示所有标签

          git tag -a v1.4 -m ‘my first version 1.4‘ 用来添加一个带有主食的标签

          git show v1.4 可以用来看这个标签的注释

          git push origin [tagname] 可以讲标签推送到服务器端

  3.git cheat-sheet

          https://training.github.com/kit/downloads/cn/github-git-cheat-sheet.html (中文版)

引用链接:http://git-scm.com/book/zh/v1

时间: 2024-10-22 19:19:18

git命令行学习思路总结的相关文章

git命令行使用

1. git命令行配置 1)安装完git客户端之后,在任意目录右键鼠标,选择Git GUI Here 2)在打开的窗口中依次选择Help->> Show SSH Key 2)如果弹出的窗口中中间部分没有key,可以点击 Generate Key 按钮,生成key,然后将生成的key拷贝一下,添加到gitlab中即可. 2. 命令使用 1)下载代码 在存放代码的目录中,右键鼠标,选择 Git Bash Here,然后会打开终端窗口 输入: git init   创建git配置目录 输入下面命令,

命令行学习

接触cocos2d-html5 v2.1.5有段时间了,最近又出了个cocos2d-js 3.0的版本,看了下要运行工程的话需要用到命令行的指令,觉得这个东西还是有点用处的. 虽然以前接触过,但是没好好的去学习,今天就找度娘聊聊命令行指令! 一.通配符*和? *表示一个字符串 ?只代表一个字符 例如:dir a?d.txt 或dir a*.*  可以找到asd.txt这个文件 二.dir irectory(目录)---主要用来显示一个目录下的文件和子目录 例如:dir e:\fff或者dir e

linux命令行学习-dig(DNS查询器)

在web开发中,总要熟悉的就是http协议,而发起一个http开始前最先要经历的一个过程就是DNS解析.简单说就是域名如何最终解析到实际服务器ip的过程. 而在研究DNS解析和排除DNS解析类故障问题的时候一个强大的工具就是dig.和他对应的有个比较传统的命令nslookup,不过dig作为更新的命令,其强大而简洁可定制的输出也使得运维其开发人员使用. 实例1(访问服务器本地DNSserver查询根域名服务器):  ~#: dig ; <<>> DiG 9.3.6-P1-RedHa

git命令行(2)

一.父提交的表示方法 1.HEAD引用 在.git/HEAD目录下存在一个HEAD文件,其记录着当前工作区对应的SHA1.如果当前工作区从某个分支检出(checkout),那么这个HEAD文件中的引用最终执行分支对应的SHA1,如果处于分离头状态(不对应分支,从某个commit检查),那么这个HEAD文件中保存的就是检出的commit SHA1. 如果我们直接使用git checkout master分支,那么HEAD的值为ref: refs/heads/master.指向.git/refs/h

【重要】使用Git命令行上传到GitHub上

[本人GitHub账号:] 用户名:chenhongshuang 密码:shuangshuang6300 邮箱:[email protected] 进入GitHub账号后 1·新建项目文件名称例demo,并且点击[Branch:master 输入 gh-pages 后回车键]::: [建好以后必须在自己电脑的任意位置建"相同项目文件名称demo"] 2·cd进入本地新建的项目文件中执行:git init 3·把文件添加到版本库中,使用命令 git add .添加到暂存区里面去,不要忘记

zookeeper基本特性与基于Linux的ZK客户端命令行学习

zookeeper常用命令行操作 通过 zkCli.sh 来打开zk客户端: [[email protected] ~]# zkCli.sh [zk: localhost:2181(CONNECTED) 0] ls 与 ls2 命令: [zk: localhost:2181(CONNECTED) 0] ls / # ls命令用于查看节点,类似于Linux中的查看目录 [zookeeper] [zk: localhost:2181(CONNECTED) 1] ls2 / # ls2命令用于查看节点

git 命令行下浏览器tig使用记录

git 命令行下浏览器tig使用记录 tig 是一款优化 git 命令行的工具,使 git 命令行更加的便捷人性化 .如果用习惯了,会上瘾. 以下是一些使用记录: 安装成功后,在 Repo 文件夹下,输入 [ tig ]+ [ Enter ]即可进入 tig 模式.此时展现在面前的将会是本地所有的 commit 记录以及分支的演化. [ j ][ k ]可上下切换选中的行,[ Enter ]可分屏查看当前 commit 记录详情,[ l ]小写的 L,全屏查看 commit 记录. [ r ]进

3.Git 命令行操作

1.Git 命令行操作(本地库操作): 1.1. 创建本地库(本地库初始化): 第一步:首先在D盘建了个名为git空文件夹,命令行中cd到这个文件夹: 第二步:通过git init命令把这个目录变成Git可以管理的仓库: 文件夹会生成一个.git目录,不用去改它,这个目录默认是隐藏的,用ls -lah命令就可以看见 注意:.git 目录中存放的是本地库相关的子目录和文件,不要删除,也不要进行修改: 参考:https://blog.csdn.net/songkuiyuansky/article/d

eclipse使用git命令行

eclipse使用git的命令行很简单,无需额外配置,类似idea的方式 在eclipse的preferences中搜索terminal,可以看见git的配置(之前计算机上装过git),就类似于idea的terminal配置一样 之后,去打开eclipse的terminal,windows->show view中选择terminal,显示terminal(或 Ctrl + Shift + Alt + T) 之前百度搜的一堆配置console方式打开git命令行,,感觉没什么意义,这边放一个配置c