新建分支
版本回退
git搜索提交歷史記錄
查找含有某個(gè)字符串的 commit
git log --grep=read
// 這條命令是查看含有 "read" 關(guān)鍵字的 git commit
部分文件的回退
更新本地的倉(cāng)庫(kù)列表
git remote update origin --prune
這里要注意下傍药,如果你的remote branch不是在origin下汉操,按你得把origin換成你的名字嫂冻。
拉取遠(yuǎn)程分支
Git fetch origin <遠(yuǎn)程分支名>
Git checkout -b <本地分支名> origin/<遠(yuǎn)程分支名>
刪除遠(yuǎn)端的git分支
git push --delete origin 分支名
重命名遠(yuǎn)端的git分支
刪除遠(yuǎn)程分支:
git push --delete origin 分支名
推送本地分支:
git push origin 分支名
4. 丟棄本次工作區(qū)中的修改
git checkout .
5. 放棄一個(gè)文件的修改
6. 一個(gè)文件回退到歷史版本
第一步: 在命令行中輸入 Git log src/main/main.c 得到該文件的commit 歷史创坞。 會(huì)得到類似下面的界面
第二步: 復(fù)制需要回退版本的hash府寒,在此假設(shè)我們回退到 d98a0f565804ba639ba46d6e4295d4f787ff2949 ,則復(fù)制該序列即可
第三步:checkout 對(duì)應(yīng)版本。格式為 git checkout <hash> <filename>, 在此即為命令行中輸入 git checkout d98a0f565804ba639ba46d6e4295d4f787ff2949 src/main/main.c
7. 項(xiàng)目回退到歷史版本
git rm 以后不再跟蹤這個(gè)文件了
git reset --hard HEAD^
git reset --hard HEAD^1
git reset --hard commitID
8. 合并2個(gè)分支
將分支上多次提交合并為一次修改到當(dāng)前分支
$ git merge --squash 分支名
$ git commit -m "message here"
項(xiàng)目中合并任務(wù)分支的方法伤提,進(jìn)入主分支,從遠(yuǎn)程拉分支下來(lái)认烁,合并改分支
git merge -no-ff Re-10.10.20-fenzhi
輸入i肿男,可以增加信息。輸入esc結(jié)束編輯却嗡,輸入:wq 保存修改的內(nèi)容
9. 清理git倉(cāng)庫(kù)的文件
刪除 untracked files
git clean -f
連 untracked 的目錄也一起刪掉
git clean -fd
連 gitignore 的untrack 文件/目錄也一起刪掉 (慎用舶沛,一般這個(gè)是用來(lái)刪掉編譯出來(lái)的 .o之類的文件用的)
git clean -xfd
在用上述 git clean 前,墻裂建議加上 -n 參數(shù)來(lái)先看看會(huì)刪掉哪些文件窗价,防止重要文件被誤刪
git clean -nxfd
git clean -nf
git clean -nfd
10. 查看文件的提交記錄
git log -p filename
git log -- filename
//讓log內(nèi)容在一行中顯示
git log --oneline
//過(guò)濾git log中包含 ‘啟動(dòng)優(yōu)化’ 的內(nèi)容
git log --oneline | grep 啟動(dòng)優(yōu)化
<u>http://www.cnblogs.com/bellkosmos/p/5923439.html</u>
11. 恢復(fù)誤刪的branch
git reflog show --date=iso
顯示Head如庭,日期和commit ID。然后再用git branch創(chuàng)建新的分支
git branch recover_branch[新分支] commit_id
12. 搜索分支
13. 從遠(yuǎn)程拉取分支
git fetch origin master
14. 搜索含有somekeyword分支的
git branch -r | grep somekeyword
15. 暫存分支
git stash
git stash list
git drop stash {0}
git clear all
16 修改最后一次commit的信息
git commit --amend
m
查詢所有分支的負(fù)責(zé)人
git for-each-ref --format='%(committerdate) %09 %(authorname) %09 %(refname)' | sort -k5n -k2M -k3n -k4n
過(guò)濾某個(gè)人負(fù)責(zé)的分支
git for-each-ref --format='%(committerdate) %09 %(authorname) %09 %(refname)' | sort -k5n -k2M -k3n -k4n | grep somebody
查看本地倉(cāng)庫(kù)對(duì)應(yīng)的遠(yuǎn)程倉(cāng)庫(kù)
git remote -v
添加遠(yuǎn)程倉(cāng)庫(kù)
git remote add [shortname] [url]
$ git remote
origin
$ git remote add pb git://github.com/paulboone/ticgit.git
$ git remote -v
origin git://github.com/schacon/ticgit.git
pb git://github.com/paulboone/ticgit.git
獲取本地用戶配置信息
git config --list
git config --list | grep user
git config --global user.name "作者"
git config --global user.email "郵箱"
git cherry-pick
git cherry-pick可以選擇某一個(gè)分支中的一個(gè)或幾個(gè)commit(s)來(lái)進(jìn)行操作(操作的對(duì)象是commit)撼港。例如坪它,假設(shè)我們有個(gè)穩(wěn)定版本的分支,叫v2.0帝牡,另外還有個(gè)開(kāi)發(fā)版本的分支v3.0往毡,我們不能直接把兩個(gè)分支合并,這樣會(huì)導(dǎo)致穩(wěn)定版本混亂靶溜,但是又想增加一個(gè)v3.0中的功能到v2.0中开瞭,這里就可以使用cherry-pick了懒震。
git cherry-pick <commit id>
git blame
查看代碼的作者信息
查看foo文件的40行-60行的作者信息
查看foo文件的40行后面的21行的作者信息
git blame -L 40,60 foo
git blame -L 40,+21 foo
參考資料
Git-基礎(chǔ)-遠(yuǎn)程倉(cāng)庫(kù)的使用
https://git-scm.com/book/zh/v1/Git-%E5%9F%BA%E7%A1%80-%E8%BF%9C%E7%A8%8B%E4%BB%93%E5%BA%93%E7%9A%84%E4%BD%BF%E7%94%A8