Code Monkey home page Code Monkey logo

git-tips's Introduction

Git 奇技淫巧 🙈

Git 常用命令集合,Fork 於tips項目

Git 是一個 「分散式版控工具」,簡單的理解版控工具:大家在寫東西的時候都用過 「復原」 這個功能,但是復原只能復原幾步,假如想要找回我三天之前的修改,光用 「復原」 是找不回來的。而 「版控工具」 能記錄每次的修改,只要提交到版本庫,你就可以找到之前任何時刻的狀態。

下面的內容就是列舉了常用的 Git 命令和一些小技巧,可以透過 "頁面內搜尋" 的方式進行快速查詢:Ctrl/Command+F

開卷必讀

如果之前未使用過 Git,可以學習 Git 小白教程入門

  1. 一定要先測試命令的效果後,再用於工作環境中,以防造成不能彌補的後果!到時候別拿著砍刀來找我
  2. 所有的命令都在 git version 2.7.4 (Apple Git-66) 下測試通過
  3. 統一概念:
    • 工作區:改動(增刪檔案和內容)
    • 暫存區(Stage):輸入命令:git add 改動的檔案名,此次改動就放到了 『暫存區』
    • 本地儲存庫(簡稱:本地):輸入命令:git commit 此次修改的描述,此次改動就放到了 』本地儲存庫』,每個 commit,我叫它為一個 『版本』。
    • 遠端儲存庫(簡稱:遠端):輸入命令:git push 遠端儲存庫,此次改動就放到了 『遠端儲存庫』(GitHub 等)
    • commit-id:輸出命令:git log,最上面那行 commit xxxxxx,後面的字串就是 commit-id
  4. 如果喜歡這個項目,歡迎 Star、提交 Pr、反饋問題😊

目錄

顯示說明訊息

git help -g

The command output as below:

The common Git guides are:
   attributes          Defining attributes per path
   cli                 Git command-line interface and conventions
   core-tutorial       A Git core tutorial for developers
   cvs-migration       Git for CVS users
   diffcore            Tweaking diff output
   everyday            A useful minimum set of commands for Everyday Git
   glossary            A Git Glossary
   hooks               Hooks used by Git
   ignore              Specifies intentionally untracked files to ignore
   modules             Defining submodule properties
   namespaces          Git namespaces
   repository-layout    Git Repository Layout
   revisions           Specifying revisions and ranges for Git
   tutorial            A tutorial introduction to Git
   tutorial-2          A tutorial introduction to Git: part two
   workflows           An overview of recommended workflows with Git

'git help -a' and 'git help -g' list available subcommands and some concept guides. See 'git help <command>' or 'git help <concept>' to read about a specific subcommand or concept.

回到遠端儲存庫的狀態

拋棄本地所有的修改,回到遠端儲存庫的狀態。

git fetch --all && git reset --hard origin/master

重設第一個 commit

也就是把所有的改動都重新放回工作區,並清空所有的 commit,這樣就可以重新提交第一個 commit 了

git update-ref -d HEAD

顯示工作區和暫存區的不同

輸出工作區暫存區的 different (不同)。

git diff

還可以顯示本地儲存庫中任意兩個 commit 之間的檔案變動:

git diff <commit-id> <commit-id>

顯示暫存區和最近版本的不同

輸出暫存區和本地最近的版本 (commit) 的 different (不同)。

git diff --cached

顯示暫存區、工作區和最近版本的不同

輸出工作區暫存區 和本地最近的版本 (commit) 的 different (不同)。

git diff HEAD

快速切換分支上一個分支

git checkout -

刪除已經合併到 master 的分支

git branch --merged master | grep -v '^\*\|  master' | xargs -n 1 git branch -d

顯示本地分支關聯遠端儲存庫的情況

git branch -vv

關聯遠端分支

關聯之後,git branch -vv 就可以顯示關聯的遠端分支名了,同時推送到遠端儲存庫直接:git push,不需要指定遠端儲存庫了。

git branch -u origin/mybranch

或者在 push 時加上 -u 參數

git push origin/mybranch -u

列出所有遠端分支

-r 參數相當於:remote

git branch -r

列出本地和遠端分支

-a 參數相當於:all

git branch -a

創建並切換到本地分支

git checkout -b <branch-name>

從遠端分支中創建並切換到本地分支

git checkout -b <branch-name> origin/<branch-name>

刪除本地分支

git branch -d <local-branchname>

刪除遠端分支

git push origin --delete <remote-branchname>

或者

git push origin :<remote-branchname>

重命名本地分支

git branch -m <new-branch-name>

查看標籤

git tag

顯示當前分支的最近的 tag

git describe --tags --abbrev=0

查看標籤詳細訊息

git tag -ln

本地創建標籤

git tag <version-number>

預設 tag 是打在最近的一次 commit 上,如果需要指定 commit 打 tag:

$ git tag -a <version-number> -m "v1.0 發佈(描述)" <commit-id>

推送標籤到遠端儲存庫

首先要保證本地創建好了標籤才可以推送標籤到遠端儲存庫:

git push origin <local-version-number>

一次性推送所有標籤,同步到遠端儲存庫:

git push origin --tags

刪除本地標籤

git tag -d <tag-name>

刪除遠端標籤

刪除遠端標籤需要先刪除本地標籤,再執行下面的命令:

git push origin :refs/tags/<tag-name>

切回到某個標籤

一般上線之前都會打 tag,就是為了防止上線後出現問題,方便快速回退到上一版本。下面的命令是回到某一標籤下的狀態:

git checkout -b branch_name tag_name

放棄工作區的修改

git checkout <file-name>

放棄所有修改:

git checkout .

恢復刪除的檔案

git rev-list -n 1 HEAD -- <file_path> #得到 deleting_commit

git checkout <deleting_commit>^ -- <file_path> #回到刪除檔案 deleting_commit 之前的狀態

以新增一個 commit 的方式還原某一個 commit 的修改

git revert <commit-id>

回到某個 commit 的狀態,並刪除後面的 commit

和 revert 的區別:reset 命令會抹去某個 commit id 之後的所有 commit

git reset <commit-id>  #預設就是-mixed參數。

git reset –mixed HEAD^  #回退至上個版本,它將重置HEAD到另外一個commit,並且重置暫存區以便和HEAD相匹配,但是也到此為止。工作區不會被更改。

git reset –soft HEAD~3  #回退至三個版本之前,只回退了commit的訊息,暫存區和工作區與回退之前保持一致。如果還要提交,直接commit即可  

git reset –hard <commit-id>  #徹底回退到指定commit-id的狀態,暫存區和工作區也會變為指定commit-id版本的內容

修改上一個 commit 的描述

git commit --amend

查看 commit 歷史

git log

查看某段程式是誰寫的

blame 的意思為『責怪』,你懂的。

git blame <file-name>

顯示本地更新過 HEAD 的 git 命令記錄

每次更新了 HEAD 的 git 命令比如 commint、amend、cherry-pick、reset、revert 等都會被記錄下來(不限分支),就像 shell 的 history 一樣。 這樣你可以 reset 到任何一次更新了 HEAD 的操作之後,而不僅僅是回到當前分支下的某個 commit 之後的狀態。

git reflog

修改作者名

git commit --amend --author='Author Name <[email protected]>'

修改遠端儲存庫的 url

git remote set-url origin <URL>

增加遠端儲存庫

git remote add origin <remote-url>

列出所有遠端儲存庫

git remote

查看兩個星期內的改動

git whatchanged --since='2 weeks ago'

把 A 分支的某一個 commit,放到 B 分支上

這個過程需要 cherry-pick 命令,參考

git checkout <branch-name> && git cherry-pick <commit-id>

給 git 命令起別名

簡化命令

git config --global alias.<handle> <command>

比如:git status 改成 git st,這樣可以簡化命令

git config --global alias.st status

存儲當前的修改,但不用提交 commit

詳解可以參考廖雪峰老師的 git 教程

git stash

保存當前狀態,包括 untracked 的檔案

untracked 檔案:新建的檔案

git stash -u

顯示所有 stashes

git stash list

回到某個 stash 的狀態

git stash apply <stash@{n}>

回到最後一個 stash 的狀態,並刪除這個 stash

git stash pop

刪除所有的 stash

git stash clear

從 stash 中拿出某個檔案的修改

git checkout <stash@{n}> -- <file-path>

顯示所有 tracked 的檔案

git ls-files -t

顯示所有 untracked 的檔案

git ls-files --others

顯示所有忽略的檔案

git ls-files --others -i --exclude-standard

強制刪除 untracked 的檔案

可以用來刪除新建的檔案。如果不指定檔案檔案名,則清空所有工作的 untracked 檔案。clean 命令,注意兩點

  1. clean 後,刪除的檔案無法找回
  2. 不會影響 tracked 的檔案的改動,只會刪除 untracked 的檔案
git clean <file-name> -f

強制刪除 untracked 的目錄

可以用來刪除新建的目錄,注意:這個命令也可以用來刪除 untracked 的檔案。詳情見上一條

git clean <directory-name> -df

顯示簡化的 commit 歷史

git log --pretty=oneline --graph --decorate --all

把某一個分支到匯出成一個bundle檔案

git bundle create <file> <branch-name>

從某個bundle檔案建立本地儲存庫

建立一個本地儲存庫,同時新建一個分支,分支內容就是上面 git bundle create 命令匯出的分支內容

git clone repo.bundle <repo-dir> -b <branch-name>

執行 rebase 之前自動 stash

git rebase --autostash

從遠端儲存庫根據 ID,拉下某一狀態,到本地分支

git fetch origin pull/<id>/head:<branch-name>

詳細顯示一行中的修改

git diff --word-diff

清除 gitignore 檔案中記錄的檔案

git clean -X -f

顯示所有 alias 和 configs

注意: config 分為:當前目錄(local)和全域(golbal)的 config,預設為當前目錄的 config

git config --local --list (當前目錄)
git config --global --list (全域)

顯示忽略的檔案

git status --ignored

commit 歷史中顯示 Branch1 有的,但是 Branch2 沒有 commit

git log Branch1 ^Branch2

在 commit log 中顯示 GPG 簽名

git log --show-signature

刪除全域設定

git config --global --unset <entry-name>

新建並切換到新分支上,同時這個分支沒有任何 commit

相當於保存修改,但是重寫 commit 歷史

git checkout --orphan <branch-name>

顯示任意分支某一檔案的內容

git show <branch-name>:<file-name>

clone 下來指定的單一分支

git clone -b <branch-name> --single-branch https://github.com/user/repo.git

忽略某個檔案的改動

關閉 track 指定檔案的改動,也就是 Git 將不會在記錄這個檔案的改動

git update-index --assume-unchanged path/to/file

恢復 track 指定檔案的改動

git update-index --no-assume-unchanged path/to/file

忽略檔案的權限變化

不再將檔案的權限變化視作改動 (Windows 適用)

git config core.fileMode false

以最後提交的順序列出所有 Git 分支

最新的放在最上面

git for-each-ref --sort=-committerdate --format='%(refname:short)' refs/heads/

在 commit log 中搜尋相關內容

通過 grep 搜尋,given-text:所需要搜尋的文字

git log --all --grep='<given-text>'

把暫存區的指定 file 放到工作區中

如果不加任何參數,預設選項是 -mixed

git reset <file-name>

強制推送

git push -f <remote-name> <branch-name>

一圖詳解

聯繫我

  • 博客園:削微寒
  • 或者直接提 Pr,Issues

⬆ 返回頂部

git-tips's People

Contributors

521xueweihan avatar agalwood avatar ccwanggl avatar codermr avatar doggy8088 avatar hcz017 avatar imuhao avatar jacknoah avatar mike-nii avatar pssdeveloper avatar zzugbb avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.