Git基础入门(四)Git历史记录管理

git clone https://github.com/schacon/simplegit-progit mytest            #获取测试项目

cd  mytest

git log                                                      #查看Git仓库的日志信息

    commit ca82a6dff817ec66f44342007202690a93763949

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Mon Mar 17 21:52:11 2008 -0700

        changed the verison number

    commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Sat Mar 15 16:40:33 2008 -0700

        removed unnecessary test code

    commit a11bef06a3f659402fe7563abf99ad00de2209e6

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Sat Mar 15 10:31:28 2008 -0700

        first commit

git log会按提交时间列出所有的更新,列出每个提交的校验和、作者的名字和电子邮件地址、提交时间以及提交说明

git log有许多选项可以帮助搜寻你所要找的信息,接下来我们介绍些最常用的

-p:显示每次提交的内容差异

-N:显示最近N次提交

git log -p -1

    commit ca82a6dff817ec66f44342007202690a93763949

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Mon Mar 17 21:52:11 2008 -0700

        changed the verison number

    diff --git a/Rakefile b/Rakefile

    index a874b73..8f94139 100644

    --- a/Rakefile

    +++ b/Rakefile

    @@ -5,7 +5,7 @@ require 'rake/gempackagetask'

     spec = Gem::Specification.new do |s|

         s.platform  =   Gem::Platform::RUBY

         s.name      =   "simplegit"

    -    s.version   =   "0.1.0"

    +    s.version   =   "0.1.1"

         s.author    =   "Scott Chacon"

         s.email     =   "schacon@gmail.com"

         s.summary   =   "A simple gem for using Git in Ruby code."

--stat:显示每次提交简略的统计信息

git log --stat -1

    commit ca82a6dff817ec66f44342007202690a93763949

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Mon Mar 17 21:52:11 2008 -0700

        changed the verison number

     Rakefile | 2 +-

     1 file changed, 1 insertion(+), 1 deletion(-)

--pretty=<format>:指定使用不同于默认格式的方式展示提交历史

    format:

        oneline将每个提交放在一行显示,查看的提交数很大时非常很有用

        full:查看作者和提交者(修改者)

        fuller:输出比full更详细的信息(提交者)

git log --pretty=oneline

    ca82a6dff817ec66f44342007202690a93763949 changed the verison number

    085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 removed unnecessary test code

    a11bef06a3f659402fe7563abf99ad00de2209e6 first commit

git log --pretty=full  -1

    commit ca82a6dff817ec66f44342007202690a93763949

    Author: Scott Chacon <schacon@gmail.com>

    Commit: Scott Chacon <schacon@gmail.com>

        changed the verison number

git log --pretty=fuller   -1

    commit ca82a6dff817ec66f44342007202690a93763949

    Author:     Scott Chacon <schacon@gmail.com>

    AuthorDate: Mon Mar 17 21:52:11 2008 -0700

    Commit:     Scott Chacon <schacon@gmail.com>

    CommitDate: Fri Apr 17 21:56:31 2009 -0700

        changed the verison number

git log --pretty=format                 #定制要显示的记录格式

git log --pretty=format:"%h - %an, %ar : %s"

    ca82a6d - Scott Chacon, 10 years ago : changed the verison number

    085bb3b - Scott Chacon, 10 years ago : removed unnecessary test code

    a11bef0 - Scott Chacon, 10 years ago : first commit

选项         说明

%H          提交对象的完整哈希字串

%h          提交对象的简短哈希字串

%T          树对象的完整哈希字串

%t          树对象的简短哈希字串

%P          父对象的完整哈希字串

%p          父对象的简短哈希字串

%an         作者的名字

%ae         作者的电子邮件地址

%ad         作者修订日期(可以用--date=选项定制格式)

%ar         作者修订日期,按多久以前的方式显示

%cn         提交者的名字

%ce         提交者的电子邮件地址

%cd         提交日期

%cr         提交日期,按多久以前的方式显示

%s          提交说明

当oneline或format与另一个log选项--graph结合使用时,这个选项添加了一些ASCII字符串来形象地展示你的分支、合并历史

git log --pretty=oneline --graph 

    * ca82a6dff817ec66f44342007202690a93763949 changed the verison number

    * 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 removed unnecessary test code

    * a11bef06a3f659402fe7563abf99ad00de2209e6 first commit

git log <PATH>          #只显示指定路径或文件的历史信息

git log README

    commit a11bef06a3f659402fe7563abf99ad00de2209e6

    Author: Scott Chacon <schacon@gmail.com>

    Date:   Sat Mar 15 10:31:28 2008 -0700

        first commit

git log的常用选项

选项                 说明

-p                  按补丁格式显示每个更新之间的差异

-N                  N代表一个数字,表示显示前N条信息

--stat              显示每次更新的文件修改统计信息

--shortstat         只显示--stat中最后的行数修改添加移除统计

--name-only         仅在提交信息后显示已修改的文件清单

--name-status       显示新增、修改、删除的文件清单

--abbrev-commit     仅显示校验和的前几个字符,而非所有的 40 个字符

--relative-date     使用较短的相对时间显示

--graph             显示ASCII图形表示的分支合并历史

--pretty            使用其他格式显示历史提交信息。可用的选项包括oneline,full,fuller和format(后跟指定格式)

--since             显示指定时间之后的提交。

--until             显示指定时间之前的提交。

--author            显示指定作者相关的提交。

--committer         显示指定提交者相关的提交。

--grep              显示含指定关键字的提交

-S                  显示添加或移除了某个关键字的提交

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Git安装和使用 Git安装和使用 刚开始用git的小白适用,,转自http://www.cnblogs.com/qijunjun/p/7137207.html 实际项目开发中,我们经常会用一些版本控制器来托管自己的代码,今天就来总结下Git的相关用法,废话不多说,直接开写。 目的:通过Git管理g
fatal: remote origin already exists.解决方法 第一个问题git remote add origin**************fatal: remote origin already exists.(报错远程起源已经存在。)上网查了下,有很多小白遇到过这个问题,以
git常用命令(二)查看历史记录 git log [--pretty=oneline] [ --oneline] / reflog Eniac-W 于 2020-10-18 18:12:38 发布 2368 收藏 3分类专栏: git 文章标签: git版权 git专栏收录该内容10 篇文章0 订阅
git之如何把本地文件上传到远程仓库的指定位置 git专栏收录该内容2 篇文章0 订阅订阅专栏2018.11.26添加内容: 对于自己的仓库,我们建议将远程仓库通过clone命令把整个仓库克隆到本地的某一路径下。这样的话我们从本地向远程仓库提交代码时,就可以直接把需要提交的文件拖到我们之前克隆下来的
代码规范之 lint-staged 在代码提交之前,进行代码规则检查能够确保进入git库的代码都是符合代码规则的。但是整个项目上运行lint速度会很慢,lint-staged能够让lint只检测暂存区的文件,所以速度很快。 安装与配置 安装husky和lint-staged: yarn add hu
方法:1、文件没有git操作时用“git checkout--文件”命令还原;2、文件提交到暂存区时用“git reset HEAD”命令回退当前版本还原;3、文件提交到仓库区时用“git reset HEAD^”命令回退上一个版本还原。 本文操作环境:Windows10系统、Git2.30.0版、
使用Git将本地文件提交到远程仓库 一 操作准备条件: git远程仓库已经建好了,本地文件已经存在了,现在要将本地代码推到git远程仓库保存。 解决办法如下: 1、(先进入项目文件夹)通过命令 git init 把这个目录变成git可以管理的仓库 git init 2、把文件添加到版本库中,使用命令
GitHub克隆代码到本地全教程 因为工作原因更换电脑,想要从GitHub上拉取代码的话需要重新配置ssh keys,时间过的久了怕忘记就把步骤给记录下来。 具体步骤: 1.安装git 这我就不说了 2.在TortoiseGit的安装文件中找到 puttygen.exe应用程序 ,默认应该都是 :C
github上传项目的时候报出git@github.com: Permission denied (publickey). fatal: Could not read from remote repo 前言 会不会有程序员小伙伴在刚开始使用github的时候上传项目的时候困难重重,但是又基于自己本身
查看历史 git log --pretty=onelinegit log (然后一直按enter键) 一个是切换根据历史里面的id切换git checkout ID git log 需要不断按enter键出来历史提交记录 git log --pretty=oneline 是直接出来历史记录
Git工作原理及常用命令 欧怼怼发布于&#160;2020-12-08 git介绍 git(读音/ɡɪt/)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。git是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。 git
git git提交项目的具体流程 git项目流程:以下主要有3个角色:负责人、成员A、成员B(若负责人也要修改代码,则负责人同时兼任2个角色:负责人、成员) 主要负责人:搭建项目架构且提交到git上1.github官网登录后,新建仓库,生成地址url,复制线上仓库.git结尾的地址url2.在一个空
git上传项目全部流程 一、下载git 进入网址:https://git-scm.com/downloads; 点击中的Download 2.16.0 for Windows; 在中选择蓝色字段点击,根据电脑64或32位选择适合的下载,点击即可进行下载,下载完成后傻瓜式安装,一直点击下一步即可完成安
Your local changes to the following files would be overwritten by checkout问题的解决 于 2018-07-17 11:38:27 发布 Git 的本地版本管理有三个部分 名称&#x9;说明工作区(Working Directory)&#x9;
Git配置SSH Keys步骤使用教程 1.若是首次安装使用git,先配置用户名称和邮箱(如果有就不需要配置) 打开Git Bash,输入 git config --global user.name &quot;姓名&quot;git config --global user.email &quot
基本配置完成,接下来就是上传你要上传的项目了。 1、初始化git 进入你要上传的项目的文件夹,在文件夹内鼠标右击,选择“Git Bash Here”打开git命令行,输入: $ git init 目的是初始化git,并且会创建个“.git”文件夹,里面有个“config”就是用来保存远程厂库路径地址
本篇内容主要讲解“gitee如何上传代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“gitee如何上传代码”吧! ...
这篇“从gitee上下的代码如何用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这...
这篇文章主要介绍“gitee如何下载仓库里的项目”,在日常操作中,相信很多人在gitee如何下载仓库里的项目问题上存在疑惑,小编查阅了各式资料,整理出简单好用的...
本篇内容主要讲解“怎么在Gitee上更新代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在Gitee上更新代...