git各种常用的命令

git各种常用的命令

介绍工作中各种常用的命令以及说明 持续更新

配置支持中文

git config --global i18n.commitencoding utf-8 --注释:该命令表示提交命令的时候使用utf-8编码集提交
git config --global i18n.logoutputencoding utf-8 --注释:该命令表示日志输出时使用utf-8编码集显示
export LESSCHARSET=utf-8 --注释:设置LESS字符集为utf-8

Git之git常用命令
git init
#创建一个Git仓库,初始化本地git仓库

git config–global user.name “输入你的用户名”
#配置你个人的用户名称
git config–global user.email “输入你的邮箱”
#配置你个人的电子邮件地址

git config–global color.ui true
#启用默认的颜色设置
git config–global color.ui false
#感觉颜色太花俏可以关闭

git clone [url]
#将存储库克隆到目录中(会在本地主机生成一个目录,与远程主机的版本库同名)
git clone [url] 本地目录名
#将存储库克隆到指定目录中(目录名作为git clone命令的第二个参数)

git status
#用于显示工作目录和暂存区的状态(查看是否有改动修改)

git add ABC
#命令将指定文件添加到索引(将修改(指定文件)添加到暂存区)
git add .

将所有修改添加到暂存区

git commit -m ‘本次提交描述’

提交文件至本地仓库区(会将git add .存入暂存区修改内容提交至本地仓库中)

git commit --amend -m ‘xxx’

改变最近一次提交(常用于反复修改)

git commit -am ‘xxx’

相当于git add . 与git commit –m “本次提交描述”两句操作合并为一句进行使用。

git rm xxx

命令用于从工作区和索引中删除文件

git rm -r *
#进入某个目录中,执行此语句,会删除该目录下的所有文件和子目录(递归删除)

git log
#查看提交历史(日志)
git log -n

查看最近n次的提交信息

git log --stat

显示被修改文件的修改统计信息,添加或删除了多少行

git log -p -n
#-p 选项展开显示每次提交的内容差异,用 -n 则仅显示最近的n次更新

git show XXX

命令用于显示各种类型的对象

git show-branch

图示当前分支历史

git show-branch --all

图示所有分支历史

git tag

列出当前仓库的所有标签(tag)

git tag tagname                               
#创建本地tag
git push --tags   

把所有tag推送到远程仓库

 git push origin tagName

把tagName推送到远程仓库

git diff
#工作区(work dict)和暂存区(stage)的比较(修改之后还没有暂存起来的变化内容)
git diff --cached

比较暂存区与最新本地版本库(本地库中最近一次commit的内容)

git diff HEAD^

比较与上一个版本的差异

git diff HEAD – ./lib

显示当前目录下的lib目录和上次提交之间的差别(更准确的说是在当前分支下)

git branch
#不带参数:列出本地已经存在的分支,并且在当前分支的前面用"*"标记
git branch -r
#查看远程版本库分支列表
git branch -a
#查看所有分支列表,包括本地和远程
git branch dev
#创建名为dev的分支,创建分支时需要是最新的环境,创建分支但依然停留在当前分支
git branch -d dev
#删除dev分支,如果在分支中有一些未merge的提交,那么会删除分支失败
git branch -D dev
#强制删除dev分支
git branch -vv
#可以查看本地分支对应的远程分支
git branch -m oldName newName
#给分支重命名
git checkout filename
#放弃单个文件的修改
git checkout .
#放弃当前目录下的修改
git checkout master
#将分支切换到master

git checkout -b master_copy

从当前分支创建新分支master_copy并检出

git checkout v1.0.3

检出版本v1.0.3

git checkout -b devel origin/develop

从远程分支develop创建新本地分支devel并检出

git checkout – README

检出head版本的README文件(可用于修改错误回退)

git merge origin/master

合并远程master分支至当前分支

git push origin master

上传本地当前分支代码到远程master分支

git fetch
#将某个远程主机的更新,全部取回本地
git fetch --prune

获取所有原创分支并清除服务器上已删掉的分支

git pull origin master

获取远程分支master并merge到当前分支

git reset --hard HEAD

将当前版本重置为HEAD(通常用于merge失败回退)

git rebase
#重新定义分支的版本库状态

git ls-files

列出git index包含的文件

git whatchanged

显示提交历史对应的文件修改

git ls-tree HEAD

内部命令:显示某个git对象

$ git stash Saved working directory and index state \ “WIP on
master: 049d078 added the index file” HEAD is now at 049d078 added the
index file (To restore them type “git stash apply”)

添加暂存

$ git stash list stash@{0}: WIP on master: 049d078 added the index
file stash@{1}: WIP on master: c264051 Revert “added file_size”
stash@{2}: WIP on master: 21d80a5 added number to log

查看所有暂存

git stash show -p stash@{0}

查看第一次暂存

git stash apply stash@{0}

应用第一次暂存

git stash apply stash@{1}

应用第二次暂存

git stash apply stash@{2}

应用第三次暂存

git stash pop

从stash里面移除最后一次添加的(一次只能移除一个 遵循后进先出)

git grep “hello world”

文件中搜索文本“hello world”

.gitignore规则

#               表示此为注释,将被Git忽略
*.a             表示忽略所有 .a 结尾的文件
!lib.a          表示但lib.a除外
/TODO           表示仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/          表示忽略 build/目录下的所有文件,过滤整个build文件夹;
doc/*.txt       表示会忽略doc/notes.txt但不包括 doc/server/arch.txt
 
bin/:           表示忽略当前路径下的bin文件夹,该文件夹下的所有内容都会被忽略,不忽略 bin 文件
/bin:           表示忽略根目录下的bin文件
/*.c:           表示忽略cat.c,不忽略 build/cat.c
debug/*.obj:    表示忽略debug/io.obj,不忽略 debug/common/io.obj和tools/debug/io.obj
**/foo:         表示忽略/foo,a/foo,a/b/foo等
a/**/b:         表示忽略a/b, a/x/b,a/x/y/b等
!/bin/run.sh    表示不忽略bin目录下的run.sh文件
*.log:          表示忽略所有 .log 文件
config.php:     表示忽略当前路径的 config.php 文件
 
/mtk/           表示过滤整个文件夹
*.zip           表示过滤所有.zip文件
/mtk/do.c       表示过滤某个具体文件
 
被过滤掉的文件就不会出现在git仓库中(gitlab或github)了,当然本地库中还有,只是push的时候不会上传。
 
需要注意的是,gitignore还可以指定要将哪些文件添加到版本管理中,如下:
!*.zip
!/mtk/one.txt
 
唯一的区别就是规则开头多了一个感叹号,Git会将满足这类规则的文件添加到版本管理中。为什么要有两种规则呢?
想象一个场景:假如我们只需要管理/mtk/目录中的one.txt文件,这个目录中的其他文件都不需要管理,那么.gitignore规则应写为::
/mtk/*
!/mtk/one.txt
 
假设我们只有过滤规则,而没有添加规则,那么我们就需要把/mtk/目录下除了one.txt以外的所有文件都写出来!
注意上面的/mtk/*不能写为/mtk/,否则父目录被前面的规则排除掉了,one.txt文件虽然加了!过滤规则,也不会生效!
 
----------------------------------------------------------------------------------
还有一些规则如下:
fd1/*
说明:忽略目录 fd1 下的全部内容;注意,不管是根目录下的 /fd1/ 目录,还是某个子目录 /child/fd1/ 目录,都会被忽略;
 
/fd1/*
说明:忽略根目录下的 /fd1/ 目录的全部内容;
 
/*
!.gitignore
!/fw/ 
/fw/*
!/fw/bin/
!/fw/sf/
说明:忽略全部内容,但是不忽略 .gitignore 文件、根目录下的 /fw/bin/ 和 /fw/sf/ 目录;注意要先对bin/的父目录使用!规则,使其不被排除
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值