首页 > 代码库 > 常用Git指令

常用Git指令

1.目录和文件

显示当前目录路径:

pwd

创建/打开目录:

//创建目录
mkdir IOS
//打开目录
open IOS

2.Git库

git配置:

git config --global user.name "Your Name"
git config --global user.email "email@example.com"
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

进入Git远程服务器

ssh git@git.gof.net

初始化远程git仓库:

sudo git init --bare sample.git

git仓库赋权:

sudo chown -R git:git sample.git

把目录变成git仓库:

git init

添加文件到仓库:

git add readme.txt

 把修改提交到仓库。-m后面输入的是提交的说明,可以输入任意内容:

git commit -m "修改Key名称"
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

查看仓库当前的状态:

git status
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

查看文件修改的内容(一般用 git status指令查看到修改的文件,然后用git diff指令查看文件具体的修改内容):

git diff UIViewController+GofHookForGA.m
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px "Hiragino Sans GB" }</style>

显示从最近到最的提交日志:

git log

同上,不同的是仅显示日志摘要信息:

git log --pretty=oneline
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

回退到上一个版本:

//HEAD表示当前版本;上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
git reset --hard HEAD^
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

回退到指定commit id的版本:

//那串数字是commit id。
//版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了
git reset --hard 3628164
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

记录每一次命令:

git reflog
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

把readme.txt文件在工作区的修改全部撤销:

git checkout -- readme.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

把暂存区的修改回退到工作区:

git reset HEAD readme.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

直接删除文件:

rm test.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

从版本库中删除文件,需要git commit:

git rm test.txt
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { } span.s3 { font: 10.0px Helvetica }</style>

本地库和远程库相关联,远程库名称为origin:

git remote add origin https://github.com/GofLee001/swiftdemo.git
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica } span.s3 { font: 10.0px "Hiragino Sans GB" }</style>

把本地库master的所有内容推送到远程库:

//加上-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
git push -u origin master
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

把本地master分支的最新修改推送至GitHub:

git push origin master
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

克隆仓库到本地:

//1.要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
//2.Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
git clone git@github.com:GofLee001/swiftdemo.git
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

创建dev分支,然后切换到dev分支: 

 git checkout -b dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

创建dev分支:

git branch dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

切换到dev分支:

git checkout dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

列出所有分支,当前分支前面会标一个*号:

git branch
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

合并指定分支dev到当前分支:

git merge dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

删除dev分支:

git branch -d dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

查看分支的合并情况:

git log --graph
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

把当前工作现场“储藏”起来,等以后恢复现场后继续工作:

git stash
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

查看保存的工作现场:

git stash list
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

恢复工作现场并删除stash:

git stash pop

//上面指令等效于下面这两条指令
git stash apply   //恢复工作现场
git stash drop  //删除stash
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

强行删除没有合并过的分支dev:

git branch -D dev
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

查看远程库的信息:

git remote
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

查看远程库的详细信息:

git remote -v
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px "Hiragino Sans GB" }</style>

推送自己的修改到远程:

git push origin branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

在本地创建和远程分支对应的分支:

git checkout -b branch-name origin/branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px "Hiragino Sans GB" }</style>

建立本地分支和远程分支的关联:

git branch --set-upstream branch-name origin/branch-name
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "Hiragino Sans GB"; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

从远程拉取分支:

git pull

tag相关操作:

//查看所有标签
git tag

//打一个新标签
git tag v1.0

//给指定的commit打标签
git tag v0.9 6224937

//创建带有说明的标签,用-a指定标签名,-m指定说明文字
git tag -a v0.1 -m "version 0.1 released" 3628164

//推送tag到远程
git push origin v1.0

//推送所有本地标签到远程
git push origin --tags

//删除本地标签
git tag -d v0.1

//删除远程的标签
git push origin :refs/tags/v0.1
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

让Git显示颜色:

git config --global color.ui true
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

更新 submodule:

git submodule update --remote
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style>

设置别名,这里status的别名是st:

git config --global alias.st status

删除submodule:

git submodule deinit 私有库名称
git rm 私有库名称
git rm --cached 私有库名称
rm -rf .git/modules/私有库名称

3.操作Podfile文件

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

创建Podfile文件:

touch Podfile
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px Helvetica; color: #000000 } span.s1 { font: 10.0px "PingFang TC" } span.s2 { }</style>

用Xcode打开Podfile文件:

open -a Xcode Podfile

4.提交podspec文件:

//1.提交到Github
pod lib lint  //pod验证
pod trunk push GofShakeAndEmail.podspec  //上传podspec文件到trunk服务器

//2.提交到私有服务器
pod repo push GofSpecs GofNetComponent.podspec

5.其他指令

修改hosts文件:

sudo vim /etc/hosts

删除指令:

x    删除光标下的字符 ("dl" 的缩写)
X    删除光标前的字符 ("dh" 的缩写)
D    从当前位置删除到行尾 ("d$" 的缩写)
dw    从当前位置删除到下一个单词开头
db    从当前位置删除到前一个单词的开头
diw    删除光标上的单词 (不包括空白字符)
daw    删除光标上的单词 (包括空白字符)
dG    删除到文件末
dgg    删除到文件首

"dl"    删除字符 (缩写: "x")            |dl|
"diw"    删除内含单词                *diw*
"daw"    删除一个单词                *daw*
"diW"    删除内含字串 (见 |WORD|)        *diW*

"daW"    删除一个字串 (见 |WORD|)        *daW*
"dd"    删除一行                |dd|
"dis"    删除内含句子                *dis*
"das"    删除一个句子                *das*
"dib"    删除内含 ( ) 块            *dib*
"dab"    删除一个 ( ) 块            *dab*
"dip"    删除内含段落                *dip*
"dap"    删除一个段落                *dap*
"diB"    删除内含 {   } 大块            *diB*
"daB"    删除一个 {   } 大块            *daB

 

 

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style> <style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style> <style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000; background-color: #ffffff } span.s1 { }</style> <style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { } span.s2 { font: 10.0px Helvetica }</style> <style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 10.0px "PingFang TC"; color: #000000 } span.s1 { }</style>

常用Git指令