Git 的初步認識

Version1.1

文檔名稱:Git的初識

撰寫人  :賈永超

撰寫時間:2017-07-12

git config --global user.name "Your Name"git

git config --global user.email "youremail@domain.com"緩存

# 客戶端需先設置連接用戶名和密碼(避免其後失誤),填寫用戶名和郵箱做爲一個標識dom

 

 

1、新建代碼庫fetch

  # 在當前目錄新建一個代碼庫,經過這個命令把這個目錄變成git能夠管理的倉庫,這個目錄是Git來跟蹤管理版本的url

  $ git initspa

2、配置指針

  # Git的配置文件爲.gitconfigorm

  # 顯示當前的git配置blog

  $ git config --list排序

3、增長/刪除

  # 添加指定文件到暫存區

  $ git add 「文件名」  可爲文件夾和文件

  $ git add .   添加本文件夾下的全部文件到緩存區

  # 添加每一個變化前,都會要求確認

  # 對於同一個文件的多處變化,能夠實現分次提交

  $ git add -p

  # 刪除工做區文件,而且將此次刪除放入暫存區

  $ git rm 「文件名

  # 中止追蹤指定文件,但該文件會保留在工做區

  $ git rm --cached 「文件名

  # 更名文件,而且將這個更名放入暫存區

  $ git mv 「修改前文件名」 「修改後文件名」 

 

4、代碼提交

  # 首先將文件提交到緩存區

  $ git add ‘文件’

  # 將緩存區文件提交到倉庫區

  $ git commit -m」註釋

  # 提交工做區自上commit以後的變化,直接到倉庫區

  $ git commit -a

  # 提交時顯示全部diff信息

  $ git commit -v

  # 使用一次新的commit,替代上一次提交  若是代碼沒有任何新變化,則用來改寫上一次commit提交的信息

  $ git commit --amend -m ‘文件名

  # 重複上一次commit,幷包括指定文件的新變化

  $ git commit --amend ‘文件名’

  # 創建遠程鏈接

  $ git remote add ‘別名’ 「遠程鏈接地址

  # 若是代碼需從本地更新並上傳執行推命令(建議:用本身所建新分支)

  $ git push ‘與遠程鏈接地址別名一致’ ‘分支名’

  # 若是須要從遠程連接獲取代碼執行拉命令

  # 執行拉命令不須要執行addcommit命令

  # 首先創建遠程鏈接

  $ git remote add ‘別名’ ‘遠程鏈接地址’

  # 執行拉命令  

  $ git pull 「與遠程鏈接別名一致」 ‘分支名’

  # 建立別名太多容易衝突 (建議:執行完命令以後進行刪除別名)

  $ git remote remove ‘別名’   //取消本地目錄下關聯的遠程庫

  # 克隆創建遠程鏈接

  $ git clone 「遠程鏈接地址

5、分支的操做

  # 分支的建立

  $ git branch ‘分支名

  # 切換分支

  $ git checkout ‘分支名

  # 列出分支

  $ git branch // 列出全部本地分支

  $ git branch -r // 列出全部遠程分支

  $ git branch -a // 列出全部本地和遠程分支

  # 新建分支,並切換到該分支

  $ git checkout -b [‘分支名’]

  # 切換到上個分支

  $ git checkout -

  # 新建分支,依然停留在當前分支

  $ git branch [‘分支名’]

  # 新建分支,與指定的遠程分支創建追蹤關係

  $ git branch --track [‘分支名’] [remote-‘遠程分支名’]

  # 創建追蹤關係,在現有分支與指定的遠程分值之間

  $ git branch --set-upstream [‘分支名’] [‘遠程分支名’]

  # 合併指定分支到當前分支

  $ git merge [‘分支名’]

  # 刪除分支

  $ git branch -d [‘分支名’]

  # 刪除遠程分支

  $ git push origin --delete [‘分支名’]

  $ git branch -dr [remote/’分支名’]

6、標籤

  # 列出全部tag

  $ git tag

  # 新建一個tag在當前commit

  $ git tag [tag]

  # 新建一個tag在指定commit

  $ git tag [tag] [commit]

  # 刪除本地tag

  $ git tag -d [tag]

  # 刪除遠程tag

  $ git push origin :refs/tags/[‘tagName’]

  # 查看tag 信息

  $ git show [tag]

  # 提交指定tag

  $ git push [remote] [tag]

  # 提交全部tag

  $ git push [remote] --tags

  # 新建分支,指向某個tag

  $ git checkout -b [branch] [tag]

7、查看信息

  # 顯示有變動的文件

  $ git status

  # 顯示當前分支的版本歷史

  $ git log

  # 顯示commit歷史,以及每次commit發生變動的文件

  $ git log --stat

  # 搜索提交歷史,根據關鍵詞

  $ git log -S [keyword]

  # 顯示某commit後的全部變更,commit佔據一行

  $ git log [tag] HEAD --pretty=format:%s

  # 顯示某個commit以後的全部變更,其"提交說明"必須符合搜索條件

  $ git log [tag] HEAD --grep feature

  # 顯示某個文件的版本歷史,包括文件更名

  $ git log --follow [file]

  $ git whatchanged [file]

  # 顯示指定文件相關的每一次diff

  $ git log -p [file]

  # 顯示過去5次提交

  $ git log -5 --pretty --oneline

  # 顯示全部提交過的用戶,按提交次數排序

  $ git shortlog -sn

  # 顯示指定文件是什麼人在什麼時間修改過

  $ git blame [file]

  # 顯示暫存區和工做區的差別

  $ git diff

  # 顯示暫存區和上一個commit的差別

  $ git diff --cached [file]

  # 顯示工做區與當前分支最新commit之間的差別 $ git diff HEAD

  # 顯示兩次提交之間的差別

  $ git diff [first-branch]...[second-branch]

  # 顯示今天你寫了多少行代碼

  $ git diff --shortstat "@{0 day ago}"

  # 顯示某次提交的元數據和內容變化

  $ git show [commit]

  # 顯示某次提交發生變化的文件

  $ git show --name-only [commit]

  # 顯示某次提交時,某個文件的內容

  $ git show [commit]:[filename]

  # 顯示當前分支的最近幾回提交

  $ git reflog

8、遠程同步

  # 下載遠程倉庫的全部變更

  $ git fetch [remote]

  # 顯示全部遠程倉庫

  $ git remote -v

  # 顯示某個遠程倉庫的信息

  $ git remote show [remote]

  # 增長一個新的遠程倉庫,並命名

  $ git remote add [shortname] [url]

  # 取回遠程倉庫的變化,並與本地分支合併

  $ git pull [remote] [branch]

  # 上傳本地指定分支到遠程倉庫

  $ git push [remote] [branch]

  # 強行推送當前分支到遠程倉庫,即便有衝突

  $ git push [remote] --force

  # 推送全部分支到遠程倉庫

  $ git push [remote] --all

9、撤銷操做

  # 恢復暫存區的指定文件到工做區

  $ git checkout [file]

  # 恢復某個commit的指定文件到暫存區和工做區

  $ git checkout [commit] [file]

  # 恢復暫存區的全部文件到工做區

  $ git checkout .

  # 重置暫存區的指定文件,與上一次commit保持一致,但工做區不變

  $ git reset [file]

  # 重置暫存區與工做區,與上一次commit保持一致 $ git reset --hard

  # 重置當前分支的指針爲指定commit,同時重置暫存區,但工做區不變

  $ git reset [commit]

  # 重置當前分支的HEAD爲指定commit,同時重置暫存區和工做區,與指定commit一致

  $ git reset --hard [commit]

  # 重置當前HEAD爲指定commit,但保持暫存區和工做區不變

  $ git reset --keep [commit]

  # 新建一個commit,用來撤銷指定commit# 後者的全部變化都將被前者抵消,而且應用到當前分支

  $ git revert [commit]

  # 暫時將未提交的變化移除,稍後再移入

  $ git stash

  $ git stash pop

10、錯誤解決方法

  A) CRLFLF錯誤

  B)   

    a) 解決方式:

      # 執行命令進行修改core.autocrlf

      git config --global core.autocrlf true

相關文章
相關標籤/搜索