關于Git和Github,你可能不知道的十件事(1)
2016-02-20 19:33:38 來源: 張伯函 segmentfault.com 評論:0 點擊:
Git和GitHub都是非常強大的工具。即使你已經使用他們很長時間,你也很有可能不知道每個細節。我整理了Git和GitHub可能提高日常效率的10個常用技巧。
一、GitHub
1.快捷鍵: t 和 w
在你的源碼瀏覽頁面,按t
可以快速進入模糊文件名搜索模式:
在你倉庫主頁,按w
可以快速進行分支過濾:
在任意 GitHub 頁面中,按?
展示當前頁面可用的快捷鍵:
2.忽略空格: ?w=1
在任意的 diff URL 添加?w=1用來整理縮進:
3.按范圍過濾提交記錄: 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 項目中全部昨天開始的提交記錄和變化:
4.按作者過濾提交記錄: ?author=github_handle
你可以通過在對比頁面 URL 中增加?author=github_handle
來按作者過濾提交記錄。例如:鏈接https://github.com/dynjs/dynjs/commits/master?author=jingweno
顯示 jingweno 對 Dynjs 的提交記錄:
5..diff 和 .patch
在比較頁面、合并請求頁面或者評論頁面的 URL 后增加.diff
或者.patch
,可以得到 diff 或者 patch 的文本格式。例如:鏈接https://github.com/rails/rails/compare/master@{1.day.ago}…master.patch
顯示 Rails 項目中全部昨天開始的提交記錄和變化的文本格式:
6.郵件回復
你可以直接在收到的 GitHub 通知郵件進行評論,不必在網站頁面中評論。GitHub 會正確的處理你的評論:
7.鏈接行
在文件展示頁面,點擊某行或者通過按SHIFT
選擇多行,URL 會有相應的改變。如果你要給你的隊友分享一段代碼是非常方便的:
8.關注用戶
在合并請求、問題或者任何評論中提到用戶,會使用戶關注全部的后續通知:
9.自動鏈接
在合并請求、問題或者任何評論中,sha和問題碼(例如:#1) 會被自動鏈接。并且,你也可以鏈接其它倉庫的 sha 或者問題碼,格式:user/repo@sha1
或者user/repo#1
。下面是一個評論中通過 sha 自動鏈接的例子:
10.hub
Hub 是 GitHub 的命令行。它提供了 Git 和 Github 之間的集成。一個最有用的命令就是在命令行輸入hub pull-request
創建 pull request。詳見 readme。
二、Git
1.git log -p FILE
查看README.md
的修改歷史,例如:
> git log -p README.md
2.git log -S’PATTERN’
例如,搜索修改符合stupid
的歷史:
> git log -S'stupid'
3.git add -p
交互式的保存和取消保存變化,使用:
> git add -p
4.git rm –cached FILE
這個命令只刪除遠程文件,例如:
> git rm --cached database.yml
刪除database.yml
被保存的記錄,但是不影響本地文件。這對刪除已經推送過的忽略文件記錄而且不影響本地文件是非常的方便的。
5.git log ..BRANCH
這個命令返回某個非 HEAD 分支的提交記錄。假如你在一個功能分支,輸入:
> git log ..master
返回全部 master 分支的歷史記錄,包括未被合并到當前分支的提交記錄。
6.git branch –merged & git branch –no-merged
這個命令返回已合并分支列表或未合并的分支列表。這個命令對合并前檢查非常有用。例如,在一個功能分支,輸入:
> git branch --no-merged
返回未合并到該分支的分支列表。
7.git branch –contains SHA
返回包含某個指定 sha 的分支列表。例如:
> git branch --contains 2f8e2b
顯示全部包含提交2f832b
的分支。這個命令對于驗證git cherry-pick
完成非常有幫助。
8.git status -s
返回一個簡單版的 git status。我設置這個命令為默認 git status 來減少噪音。
9.git reflog
顯示你在本地已完成的操作列表。
10.git shortlog -sn
顯示提交記錄的參與者列表。和 GitHub 的參與者列表相同。
11.Summary
Git 是一個設計良好的工具。了解它可以直接讓你更有效率并成為一個更有才華的程序員。GitHub,在另一個方面,在 Git 基礎上提供便利的團隊合作特性。有能力使用 GitHub 也會提高你日常效率。
為了更好的加深你對的 Git 和 Github 了解,我推薦一些資料:
- ProGit, 最好的 Git 指南
- Advanced Git
- Git and GitHub Secrets
【編輯推薦】
