Github基本操作2018-10-28

本文說明在Git的基本操作指令

基礎(chǔ)是已經(jīng)下載了Git Bash饵婆,配置了用戶名郵箱和SSH密鑰
具體參考了《GITHUB入門與實(shí)踐》第4章

1 基本操作

1.1 git init ---- 初始化倉庫

$ mkdir git-tutorial
$ cd git-tutorial
$ git init

1.2 git status ---- 查看倉庫狀態(tài)

插入一個(gè)README.md

$ touch README.md
$ git status

1.3 git add ---- 向暫存區(qū)添加文件

上面添加的文件只是在當(dāng)前工作目錄中勺馆,但是不會被計(jì)入Git倉庫的版本管理對象中
因此用git status查看時(shí),README.md為Untracked files侨核。

 $ git add README.md
 $ git status

1.4 git commit --- 保存?zhèn)}庫的歷史記錄

git commit 可以將暫存區(qū)中的文件實(shí)際保存到git倉庫的歷史記錄中草穆,通過這些記錄,可以在工作樹中復(fù)原文件搓译。

$ git commit -m "First commit"

1.5 git log --- 查看提交日志

$ git log
$ git log -pretty=short

顯示文件的改動(dòng):

$ git log -p README.md

1.6 git diff --- 查看更改前后的差別

比較的是工作樹和暫存區(qū)之間的差別悲柱。
如果比較工作樹與最新提交之間的區(qū)別,請使用:

$ git diff HEAD

2 分支的操作

2.1 git branch --- 顯示分支一覽表

image.png

其中master前面的*表示這是我們當(dāng)前所在的分支些己。

2.2 git checkout -b --- 創(chuàng)建豌鸡、切換分支

$ git checkout -b feature-A

此時(shí)創(chuàng)建了分支 feature-A,并且工作在該分支下

2.3 切換分支 git checkout

切換回主分支為:

$ git checkout master

切換到上一個(gè)分支為:

$ git checkout -

2.4 遇到如下問題

XXXX@LAPTOP-L9R6BKCR MINGW64 /c/01-02-GIT/git-tutorial (master)
$ git checkout feature-A
error: Your local changes to the following files would be overwritten by checkout:
README.md
Please commit your changes or stash them before you switch branches.
Aborting

刪除.git文件夾下的index.lock文件即可

2.5 git merge 合并分支

將feature-A合并到master分支中

 $ git checkout master
 $ git merge --no-ff feature-A

2.6 git log --graph 以圖表形式查看分支

3 更改提交的操作

3.1 git reset --- 更改提交的版本

$ git reset --hard 哈希值

回退到原來的master分支后段标,README.md中內(nèi)容變回原內(nèi)容直颅。
此時(shí)建立分支fix-B,在分支B中修改README.md中的內(nèi)容怀樟。

git log只能看以當(dāng)前狀態(tài)為終點(diǎn)的歷史日志。如果需要看全部狀態(tài)的歷史日志盆佣,需要輸入:

$ git reflog

3.2 取消沖突

例如我們要將兩個(gè)分支feature-A和fix-B進(jìn)行合并
使用 git merge --no-ff fix-B指令后往堡,會報(bào)錯(cuò)“Merge Conflict in README.md”,這就是沖突共耍。
此時(shí)打開README.md會發(fā)現(xiàn)其中內(nèi)容比較混亂虑灰,可以將其修改為想要的值,再add和commit痹兜。

3.3 git commit --amend --- 修改提交信息

用于修改之前提交時(shí)的提交信息內(nèi)容穆咐。

3.4 git rebase -i --- 壓縮歷史

4 推送至遠(yuǎn)程倉庫

首先要在github上創(chuàng)建一個(gè)倉庫,將其設(shè)置為本地倉庫的遠(yuǎn)程倉庫
Github上創(chuàng)建的倉庫路徑為:git@github.com:用戶名/git-tutorial.git

4.1 git remote add --- 添加遠(yuǎn)程倉庫

$ git remote add origin git@github.com:xxxxx/git-tutorial.git  

4.2 git push --- 推送至遠(yuǎn)程倉庫

  • 推送至master分支
    $ git push -u origin master

此時(shí)報(bào)錯(cuò):
ERROR: Repository not found.
fatal: Could not read from remote repository.

解決方法:

$ git remote set-url origin git@github.com:xxxx/git-tutorial.git

再進(jìn)行g(shù)it push即可。

  • 推送至master以外的分支
    先在本地倉庫創(chuàng)建分支D:

    $ git checkout -b feature-D
    

再push:

$ git push -u origin feature-D

5 從遠(yuǎn)程倉庫獲取

5.1 git clone --- 獲取遠(yuǎn)程倉庫

  • 獲取遠(yuǎn)程倉庫
    在另一個(gè)文件夾中对湃,打開git bash

    $ git clone git@github.com:xxxx/git-tutorial.git

就將遠(yuǎn)程倉庫中的master分支拷貝過來了崖叫。

  • 獲取遠(yuǎn)程的feature-D分支

    $ git checkout -b feature-D origin/feature-D

  • 向本地feature-D分支提交更改
    修改本地文件后,使用git diff查詢更改
    使用下面命令進(jìn)行add和commit

    $ git commit -am "Add feature-D"

  • 推送feature-D分支

    $ git push

5.2 git pull --- 獲取最新遠(yuǎn)程分支

打開原來的項(xiàng)目文件夾(其中feature-D中文件未更新)

$ git pull origin feature-D

即可獲取最新遠(yuǎn)程分支到本地拍柒。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末心傀,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子拆讯,更是在濱河造成了極大的恐慌脂男,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件种呐,死亡現(xiàn)場離奇詭異宰翅,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)爽室,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進(jìn)店門汁讼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人肮之,你說我怎么就攤上這事掉缺。” “怎么了戈擒?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵眶明,是天一觀的道長。 經(jīng)常有香客問我筐高,道長搜囱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任柑土,我火速辦了婚禮蜀肘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘稽屏。我一直安慰自己扮宠,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布狐榔。 她就那樣靜靜地躺著坛增,像睡著了一般。 火紅的嫁衣襯著肌膚如雪薄腻。 梳的紋絲不亂的頭發(fā)上收捣,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天,我揣著相機(jī)與錄音庵楷,去河邊找鬼罢艾。 笑死楣颠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的咐蚯。 我是一名探鬼主播童漩,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼仓蛆!你這毒婦竟也來了睁冬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤看疙,失蹤者是張志新(化名)和其女友劉穎豆拨,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體能庆,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡施禾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了搁胆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弥搞。...
    茶點(diǎn)故事閱讀 39,926評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖渠旁,靈堂內(nèi)的尸體忽然破棺而出攀例,到底是詐尸還是另有隱情,我是刑警寧澤顾腊,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布粤铭,位于F島的核電站,受9級特大地震影響杂靶,放射性物質(zhì)發(fā)生泄漏梆惯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧瓦灶,春花似錦、人聲如沸怯屉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蚀之。三九已至,卻和暖如春捷泞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背寿谴。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工锁右, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓咏瑟,卻偏偏與公主長得像拂到,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子码泞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容