`
bugtags
  • 浏览: 27546 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

8 个 Git 的小技巧

Git 
阅读更多

git 已经成为了我日常必备工具之一,我总结我几乎每天使用的8个有用(且简洁)的git技巧


 

使用-p选择性添加

当你想提交内容时,你可以通过使用 git commit -am 来选择所有文件或使用 git add file 来添加特定文件。然而,有时候你可能想只添加文件的一部分来提交。你可以用 git add -p 交互性地选择哪些你想提交的部分。

在选择完你所想要提交的区块后,只需要做一个 git commit(没有 -a),这样只会提交选中的部分。同样可以使用 git checkout -p 来选择需要恢复的部分。添加后,你可以使用 git diff –cached 来查看差异。

交互式的重建基准(Interactive Rebase)

如果你在一个分支上工作,同时进行了一些 WIP 提交(commit) ,以用来压缩合并(squash)或者删除一个提交(commit)以及这个提交的恢复, 你可以做一个交互式的重建基准(rebase),用来重新组织提交。

为了做到这点,你需要运行命令 git rebase -i ,这里的是你想要重写之前的一个提交(commit)的sha1值。接下来,它将在你的编辑器(在$EDITOR环境变量,或者git配置里面指定的编辑器)上面打开一些指令,用来变更提交(commit)历史,你可以选择压缩合并(将两次提交合并为一次新的提交),重写(变更提交信息),编辑甚至删除一个提交(commit)。

请注意这改变了历史信息,因此,如果你提交了这个变更,你将不得不再一次强制提交(push),所以,绝不要在主分支,或者有其他人(除你之外)在使用的分支上面做这个操作。

储藏(Stashing)

如果你正忙于什么事情,你必须更改文本去修复其他问题,去git stash查到到储藏在当前中的更改。然而,过一段时间后,你可能就会忘记关于这个已储藏的变更。因此,我试着去保持一个储藏0(就像收件箱0如果没有储藏的情况)规则。每一次我储藏一个美元信号出现在我的输出,并且我通过git stash show -p检查,还可以通过git stash pop弹出或者通过git stash clear丢弃。

全局gitignore

在项目的根目录,你可以通过文件.gitignore来指定git需要忽略的文件。但是,如果存在git需要忽略的文件,同时,你又是唯一创建这个文件的人(如vim的 bkp文件,编辑器或者操作系统生成的一些文件,如OSX生成的.DS_Store文件),你可以在配置文件中指定全局的gitignore文件,它和工程中的.gitignore文件使用一样的语法格式。

git config --global core.excludesfile=/Users/flores/.gitignore

空格警告

我不得不承认:有时候我忘记代码尾部的一些空格。但是,通常我不会提交它们,因为我使用了这个选项:apply.whitespace=warn。每次我通过git add -p增加文件中的一大块代码,同时,这个代码块尾部包含空格,由于git给出警告提示,因此我可以在提交前修正它们。

自动重建代码基准(Auto setup rebase)

另一个很酷的技巧是自动重建代码基准(auto setup rebase)。如果你有一个分支,并做了一些commit但并未push。同时,其他人也在这个分支上进行了commit和push。当你pull的时候,git会创建一个commit来合并你的commit到上游(upstream)commit。由于这个commit毫无意义,我更倾向于,在pull时,通过配置来自动重建代码基准(auto setup rebase):branch.autosetuprebase=always。设置之后,每个pull操作,git都会尝试在当前版本的上游(upsteam)分支重新使用你的commit。

更好的日志(logging)

你是否尝试过在一个分支中找一个特定的提交啊? git log 给我们提供了一些基本的信息,不过你使用下面的命令会得到更多有用的信息:

git log --graph --decorate --pretty=oneline --abbrev-commit

–graph 会在各个提交之间打印出线条,这些线条可以展示出分支之间的关系。

–decorate 显示出分支处在哪一次提交上。

–pretty=oneline 只是在一行中显示 sha1 和 提交的注释(译者将title一词应对到更精确的注释)

–abbrev-commit 用开始的7个sha1字符代替整个sha1(他在你的仓库中是唯一的)。

你可以到explain shell去看这些选项的更详细(且是完整)的解释。

改写提交的注释

如果你在提交代码的时候注释不能准确的描述当前提交,或者你写了错别字。你可以使用 git commit –amend 来改写你已经提交的注释。 他允许你在命令行中通过 -m 选项来指定新注释或直接打开系统默认编辑器让你来编辑新的注释。  另外你还可以把一些新的变化加入到上一次提交中。请记住 该操作和 Interactive Rebase 一样,他会改变提交历史。如果你已经把你改动的这次提交push了,那么你需要强制(force)push这次变化。

欢迎你在评论中分享你在工作中发现一些能提升工作效率的 git小技巧。

本文转自:码农网


 
分享到:
评论

相关推荐

    Git入门和技巧

    Git入门和技巧,关于Git的基本操作,快速上手Git,图文说明更简洁

    Git中文学习手册 Git入门

    2 8 小结 3 Git 分支 3 1 何谓分支 3 2 分支的新建与合并 3 3 分支的管理 3 4 利用分支进行开发的工作流程 3 5 远程分支 3 6 分支的衍合 3 7 小结 4 服务器上的 Git 4 1 协议 4 2 在服务器上部署 Git 4 ...

    Git 魔法 by Ben Lynn

    Git [http://git.or.cz/] 堪称版本控制瑞士军刀。这个可靠、多才多艺、用途多样的校 订工具异常 灵活,以致不易掌握,更别说精通了。 正如Arthur C.... 小技巧如何工作,以及如何组合这些技巧以满足你的需求。

    git使用小教程

    git安装,使用的小技巧,让git记住密码,去除和发现Trailing spaces等等

    Git使用技巧.docx

    也可以直接从AppStore安装Xcode,Xcode集成了Git,不过默认没有安装,你需要运行Xcode,选择菜单“Xcode”->“Preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点“Install”就可以完成...

    Git小技巧-指令别名及使用BeyondCompare作为差异比较工具

    本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率。...指令别名就是给一些常用的指令设置一个较短的指令别名来提高Git的使用效率。如gitst(gitstatus):使用指令别名,并不会把原指令覆盖掉,而是

    progit(git中文文档)

    目的 普通工作流以及接受他人的贡献,GitHub 的可编程接口和那些能够让你的生活变得更简单的小技巧。 *第七章*关于 Git 的高级命令。你将学习到一些高级主题,诸如掌握可怕的“reset”命令,使用二分搜索识别错 误,...

    Git开发操作文档 全面介绍Git技术

    这份Git开发操作文档是一份全面介绍Git技术的文档,内容包括了Git的基本概念、使用方法和常见问题解决方案,以及...通过学习这份文档,读者可以全面掌握Git技术的应用方法和技巧,提高自己在软件开发领域的技术水平。

    Git学习手册

    2 8 小结 3 Git 分支 3 1 何谓分支 3 2 分支的新建与合并 3 3 分支的管理 3 4 利用分支进行开发的工作流程 3 5 远程分支 3 6 分支的衍合 3 7 小结 4 服务器上的 Git 4 1 协议 4 2 在服务器上部署 Git 4 3...

    Git使用小技巧之回滚与撤销详解

    主要给大家介绍了关于Git使用小技巧之回滚与撤销的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Git具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

    GIT中文资源

    2.7 技巧和窍门 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 2.7.1 自动完成 . . . . . . . . . . . . . . . . . . . . . . . . . . 40 2.7.2 Git 命令别名 . . . . . . . . . . . . . . . . . ....

    git相关问题解决

    该文档解决使用git时遇到的相关问题,文档中都有一一列出,如提交操作顺序,遇到的问题以及解决方式,小技巧小窍门等。

    git-puf-noktalari:我的新迷你书介绍了我们在日常生活中使用的版本控制系统GIT的一些小技巧。

    GIT技巧 GIT是一种近年来作为修订控制系统而声名狼藉的车辆。 在本书中,我将介绍您在日常开发例程中可能经常遇到的问题。 此外,我将分享我随着时间推移收集并从笔记中收集来的技巧。 什么是提交消息? 好的提交...

    Git::lemon:Git的基本教程,以及一些常用的操作指令,表情包系列,Markdown教程及常用布局和小技巧,文档化文档站点生成器入手等。还有一个Hexo + Github简单快速搭博客的教程说明,例如,我的博客,欢迎访问!

    Git::lemon:Git的基本教程,以及一些常用的操作指令,表情包系列,Markdown教程及常用布局和小技巧,文档化文档站点生成器入手等。还有一个Hexo + Github简单快速搭博客的教程说明,例如,我的博客,欢迎访问!

    dotfiles:使用git裸技巧从我的dotfiles配置中轻松备份

    点文件这是我的dotfiles配置。 点文件是一个以点(句点)开头的Unix文件,它保存了许多Unix程序的配置。... 使用以下git命令: git init --bare < path> 这将创建一个git存储库,该存储库具有我们通常不接触的对象,但

    git 使用及常用命令

    本文是关于git 的使用和一些git使用小技巧,以及git的常用命令,进行的整理,希望能帮助有需要的小伙伴

    Git本地仓库基本操作及技巧

    主要介绍了Git本地仓库基本操作及一些小技巧,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

    基于Git的常用撤销技巧与解决冲突方法(推荐)

    下面小编就为大家带来一篇基于Git的常用撤销技巧与解决冲突方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望对大家有所帮助

    git-tutor:+ md = git日志中的精彩教程

    将markdown写入您的提交消息–稍后使用单个命令即可获得不错的教程示例教程一些规则保持较小的提交并解释您正在编写的几乎每一行代码将markdown写入您的提交消息不要跳过任何东西。 简单的复制粘贴应该可以重现您的...

Global site tag (gtag.js) - Google Analytics