关于Git和Github你不知道的十件事

本文为翻译文章。原文链接:Ten Things You Didn't Know Git And GitHub Could Do


Git 和 GitHub都是非常强大的工具。即使你已经使用他们很长时间,你也很有可能不知道每个细节。我整理了Git和GitHub可能提高日常效率的10个常用技巧。

GitHub

快捷键: t 和 w

在你的源码浏览页面,按t可以快速进入模糊文件名搜索模式:

clipboard.png

在你仓库主页,按w可以快速进行分支过滤:

clipboard.png

在任意GitHub页面中,按?展示当前页面可用的快捷键:

clipboard.png

忽略空格: ?w=1

在任意的diff URL添加?w=1用来整理缩进:

clipboard.png

按范围过滤提交记录: master@{time}..master

你可以创建一个对比页面通过使用URL github.com/user/repo/compare/{range}。范围(range)可以是两个SHA例如sha1…sha2或者两个分支名称例如master…my-branch。范围同时也非常智能的支持使用时间作为关注点。你可以通过master@{1.day.ago}…master过滤从昨天开始的提交。例如:链接,https://github.com/rails/rails/compare/master@{1.day.ago}…master显示Rails项目中全部昨天开始的提交记录和变化:

clipboard.png

按作者过滤提交记录: ?author=github_handle

你可以通过在对比页面URL中增加?author=github_handle来按作者过滤提交记录。例如:链接https://github.com/dynjs/dynjs/commits/master?author=jingweno显示jingweno对Dynjs 的提交记录:

clipboard.png

.diff 和 .patch

在比较页面、合并请求页面或者评论页面的URL后增加.diff或者.patch,可以得到diff或者patch的文本格式。例如:链接https://github.com/rails/rails/compare/master@{1.day.ago}…master.patch显示Rails项目中全部昨天开始的提交记录和变化的文本格式:

clipboard.png

邮件回复

你可以直接在收到的GitHub通知邮件进行评论,不必在网站页面中评论。GitHub会正确的处理你的评论:

clipboard.png

链接行

在文件展示页面,点击某行或者通过按SHIFT选择多行,URL会有相应的改变。如果你要给你的队友分享一段代码是非常方便的:

clipboard.png

关注用户

在合并请求、问题或者任何评论中中提到用户会使用户关注全部的后续通知:

clipboard.png

自动链接

在合并请求、问题、或者任何评论中,sha和问题码(例如:#1)会被自动链接。并且,你也可以链接其它仓库的sha或者问题码,格式:user/repo@sha1或者user/repo#1。下面是一个评论中通过sha自动链接的例子:

clipboard.png

hub

Hub 是 GitHub的命令行。它提供了Git和Github之间的集成。一个最有用的命令就是在命令行输入hub pull-request创建pull request。详见readme.

Git

git log -p FILE

查看README.md的修改历史,例如:

> git log -p README.md

git log -S’PATTERN’

例如,搜索修改符合stupid的历史:

> git log -S'stupid'

git add -p

交互式的保存和取消保存变化,使用:

> git add -p

git rm –cached FILE

这个命令只删除远程文件,例如:

> git rm --cached database.yml

删除database.yml被保存的记录,但是不影响本地文件。这对删除已经推送过的忽略文件记录而且不影响本地文件是非常的方便的。

git log ..BRANCH

这个命令返回某个非HEAD分支的提交记录。假如你在一个功能分支,输入:

> git log ..master

返回全部master分支的历史记录,包括未被合并到当前分支的提交记录。

git branch –merged & git branch –no-merged

这个命令返回已合并分支列表或未合并的分支列表。这个命令对合并前检查非常有用。例如,在一个功能分支,输入

> git branch --no-merged

返回未合并到该分支的分支列表。

git branch –contains SHA

返回包含某个指定sha的分支列表。例如:

> git branch --contains 2f8e2b

显示全部包含提交2f832b的分支。这个命令对于验证git cherry-pick完成非常有帮助。

git status -s

返回一个简单版的git status。我设置这个命令为默认git status来减少噪音。

git reflog

显示你在本地已完成的操作列表。

git shortlog -sn

显示提交记录的参与者列表。和GitHub的参与者列表相同。

Summary

Git是一个设计良好的工具。了解它可以直接让你更有效率并成为一个更有才华的程序员。GitHub,在另一个方面,在Git基础上提供便利的团队合作特性。有能力使用GitHub也会提高你日常效率。

为了更好的加深你对的Git和Github了解,我推荐一些资料:


我本楚狂人,凤歌笑孔丘

4.3k 声望
163 粉丝
0 条评论
推荐阅读
SpringBoot安装Sentry
我们可以通过Sentry来收集线上错误日志并进行告警、监控及任务分配处理 初始化项目 通过Spring initializr初始化项目。 依赖: Spring Web 集成Sentry 在pom.xml中dependencies节点下添加如下配置 {代码...} 添加...

张伯函6阅读 4.6k评论 4

一个开源vue网站博客,nuxt开源网站,前后端分离项目
开媛笔记,基于nuxt ssr首屏服务器端渲染 。用于分享、记录、交流和学习,希望可以帮助到小伙伴们。同时网站在不断更新,创造属于猿(媛)的世界 -$Bao Yalong ..Let's Go! [链接]

jigsaw16阅读 8.4k评论 3

Git操作不规范,战友提刀来相见!
年终奖都没了,还要扣我绩效,门都没有,哈哈。这波骚Git操作我也是第一次用,担心闪了腰,所以不仅做了备份,也做了笔记,分享给大家。问题描述小A和我在同时开发一个功能模块,他在优化之前的代码逻辑,我在开...

王中阳Go5阅读 1.8k评论 2

封面图
Git 入门与实践
Git 入门与实践推荐:猴子都能懂的 GIT 入门Git --everything-is-loca 官方文档Git 教程-廖雪峰Git 的使用方式有很多。图形化 —— 小乌龟(Tortoise Git )、命令行—— git bash、IDE 集成等 ......目录1. 基础配置...

RainBow1阅读 2.2k

NB的Github项目,看到最后一个我惊呆了!
最近看到不少好玩的、实用的 Github 项目,就来给大家推荐一把。中国制霸生成器最近在朋友圈非常火的一个小网站,可以在线标记 居住、短居、游玩、出差、路过 标记后可生成图片进行社区分享,标记过的信息会记录...

艾小仙5阅读 1.5k评论 1

git patch常用方法
针对指定的commit range生成patch,默认对每一个commit分别单独生成patch文件。patch文件按照commit的先后顺序从1开始编号。patch文件会生成到当前目录下。

黑暗森林1阅读 13.1k评论 1

openSSH升级公钥失效Permission denied (publickey)解决方案
背景centos系统升级openSSH后,服务器上无法再拉取代码,报错如下:原因服务器重新安装SSH后公钥改变,需要重新安装ssh-keygen -t rsa -C "邮箱地址"生成公钥,删除gitlab原有公钥,但是git pull依然报错如下:依...

兰俊秋雨1阅读 1.2k

我本楚狂人,凤歌笑孔丘

4.3k 声望
163 粉丝
宣传栏