Git常用命令大全,迅速提升你的Git水平

来源:http://www.cnblogs.com/bbhhh/archive/2017/07/14/Git.html
-Advertisement-
Play Games

初始化本地git倉庫(創建新倉庫) git init 配置用戶名 git config --global user.name "xxx" 配置郵件 git config --global user.email "[email protected]" git status等命令自動著色 git config -- ...


初始化本地git倉庫(創建新倉庫)

git init


配置用戶名

git config --global user.name "xxx"

配置郵件

git config --global user.email "[email protected]"

git status等命令自動著色

git config --global color.ui true
git config --global color.status auto
git config --global color.diff auto
git config --global color.branch auto
git config --global color.interactive auto


clone遠程倉庫

git clone git+ssh://[email protected]/VT.git


查看當前版本狀態(是否修改)

git status


添加xyz文件至index

git add xyz


增加當前子目錄下所有更改過的文件至index

git add .


提交

git commit -m 'xxx'


合併上一次提交(用於反覆修改)

git commit --amend -m 'xxx'


將add和commit合為一步

git commit -am 'xxx'


刪除index中的文件

git rm xxx


遞歸刪除

git rm -r *


顯示提交日誌

git log


顯示1行日誌 -n為n行

git log -1
git log -5


顯示提交日誌及相關變動文件

git log --stat
git log -p -m


顯示某個提交的詳細內容

git show dfb02e6e4f2f7b573337763e5c0013802e392818


可只用commitid的前幾位

git show dfb02


顯示HEAD提交日誌

git show HEAD


顯示HEAD的父(上一個版本)的提交日誌 ^^為上兩個版本 ^5為上5個版本

git show HEAD^


顯示已存在的tag

git tag


增加v2.0的tag

git tag -a v2.0 -m 'xxx'


顯示v2.0的日誌及詳細內容

git show v2.0


顯示v2.0的日誌

git log v2.0


顯示所有未添加至index的變更

git diff


顯示所有已添加index但還未commit的變更

git diff --cached


比較與上一個版本的差異

git diff HEAD^


比較與HEAD版本lib目錄的差異

git diff HEAD -- ./lib


比較遠程分支master上有本地分支master上沒有的

git diff origin/master..master


只顯示差異的文件,不顯示具體內容

git diff origin/master..master --stat


增加遠程定義(用於push/pull/fetch)

git remote add origin git+ssh://[email protected]/VT.git


顯示本地分支

git branch


顯示包含提交50089的分支

git branch --contains 50089


顯示所有分支

git branch -a


顯示所有原創分支

git branch -r


顯示所有已合併到當前分支的分支

git branch --merged


顯示所有未合併到當前分支的分支

git branch --no-merged


本地分支改名

git branch -m master master_copy


從當前分支創建新分支master_copy並檢出

git checkout -b master_copy


上面的完整版

git checkout -b master master_copy


檢出已存在的features/performance分支

git checkout features/performance


檢出遠程分支hotfixes/BJVEP933並創建本地跟蹤分支

git checkout --track hotfixes/BJVEP933


檢出版本v2.0

git checkout v2.0


從遠程分支develop創建新本地分支devel並檢出

git checkout -b devel origin/develop


檢出head版本的README文件(可用於修改錯誤回退)

git checkout -- README


合併遠程master分支至當前分支

git merge origin/master

合併提交ff44785404a8e的修改

git cherry-pick ff44785404a8e


將當前分支push到遠程master分支

git push origin master


刪除遠程倉庫的hotfixes/BJVEP933分支

git push origin :hotfixes/BJVEP933


把所有tag推送到遠程倉庫

git push --tags


獲取所有遠程分支(不更新本地分支,另需merge)

git fetch


獲取所有原創分支並清除伺服器上已刪掉的分支

git fetch --prune


獲取遠程分支master並merge到當前分支

git pull origin master

重命名文件README為README2

git mv README README2


將當前版本重置為HEAD(通常用於merge失敗回退)

git reset --hard HEAD
git rebase


刪除分支hotfixes/BJVEP933(本分支修改已合併到其他分支)

git branch -d hotfixes/BJVEP933

強制刪除分支hotfixes/BJVEP933

git branch -D hotfixes/BJVEP933

列出git index包含的文件

git ls-files

圖示當前分支歷史

git show-branch


圖示所有分支歷史

git show-branch --all


顯示提交歷史對應的文件修改

git whatchanged


撤銷提交dfb02e6e4f2f7b573337763e5c0013802e392818

git revert dfb02e6e4f2f7b573337763e5c0013802e392818


內部命令:顯示某個git對象

git ls-tree HEAD


內部命令:顯示某個ref對於的SHA1 HASH

git rev-parse v2.0


顯示所有提交,包括孤立節點

git reflog
git show HEAD@{5}


顯示master分支昨天的狀態

git show master@{yesterday}


圖示提交日誌

git log --pretty=format:'%h %s' --graph
git show HEAD~3
git show -s --pretty=raw 2be7fcb476


暫存當前修改,將所有至為HEAD狀態

git stash


查看所有暫存

git stash list


參考第一次暫存

git stash show -p stash@{0}


應用第一次暫存

git stash apply stash@{0}


文件中搜索文本“delete from”

git grep "delete from"
git grep -e '#define' --and -e SORT_DIRENT
git gc
git fsck


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 會話控制 概念: 在同一個網站上,多個頁面切換時,保持用戶登錄狀態,訪問的都登錄用戶是自己的信息; 在網站中跟蹤一個用戶,處理在同一個網站中同一個用戶在多個頁面為其共用數據! 允許伺服器跟蹤同一個客戶端做出的連續請求! 緣由: 訪問web頁面要使用’ HTTP 協議’ 實現, 而HTTP 協議是無狀 ...
  • Iterator介面也是Java集合框架的成員,與Collection和Map兩個系列的集合不一樣的是Collection和Map系列主要用於充當容器的作用,而Iterator正如其名字一樣是主要用於迭代訪問Collection集合中的元素,Iterator對象也被稱為迭代器。 Iterator介面 ...
  • 看的過程中,發現好多模式都用過,只是沒有總結,或者是不知道叫這個名字吧··· 這裡列舉結構型模式,適配器、橋接、過濾、組合、裝飾器、外觀、享元、代理, 適配器模式:將現存的對象放到新的環境裡邊去,但是介面不一樣,其實就是添加一個類把新的介面包裝一樣 之前公司的wcf服務端就是這種模式,公司很多部門, ...
  • 在開始autofac時,有必要先瞭解兩個關鍵詞:“控制反轉(IoC/Inverse Of Control)”與“依賴註入(DI/Dependence injection)”。 控制反轉(IoC):它把傳統上由程式代碼直接操控的對象的調用權交給容器,通過容器來實現對象組件的裝配和管理。 依賴註入(DI ...
  • 面試問到這個··答不出來就是沒有架構能力···這裡學習一下···面試的時候直接讓我說出26種設計模式··當時就懵逼了··我記得好像之前看的時候是23種的 還有3個是啥的··· 這裡先列出幾種創建型模式,工廠、抽象工廠、單例,建造者、原型,後續在更新 工廠模式:缺點是每增加一個類型就得增加一個工具類和 ...
  • 前面的話 每次寫HTML結構涉及到CSS命名時,都要掙扎一番。關於CSS命名的規範,市面上有不少,如OOCSS、SMACSS、BEM和MVCSS等。在這裡面最火的應該算BEM了。本文將詳細介紹CSS命名 主流命名 【BEM】 說起CSS命名,當然要提到BEM。BEM的意思就是B模塊(block)、E ...
  • 工作中遇到的功能點,覺得以後可以復用,就打算備一下咯 格式要求(例):On Friday, July 14, 2017 我的思路是用js就可以實現了,具體代碼如下: ...
  • 前面的話 由歷史原因及個人習慣引起的 DOM 結構、命名不統一,導致不同成員在維護同一頁面時,效率低下,迭代、維護成本極高。所以,使用統一的命名規範非常必要。本文將詳細介紹命名規範 目錄命名 1、項目文件夾:projectname 2、樣式文件夾:css 3、腳本文件夾:js 4、樣式類圖片文件夾: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...