git常用命令详解(2)

简介: git常用命令详解(2)

6. git rev-parse

准备工作

在工作区中建立目录 a/b/c ,进入该目录中。

cd /path/to/my/workspace/demo/
mkdir -p a/b/c
cd /path/to/my/workspace/demo/a/b/c

显示版本库 .git 目录所在的位置。

$ git rev-parse --git-dir
/path/to/my/workspace/demo/.git

显示工作区根目录。

$ git rev-parse --show-toplevel
/path/to/my/workspace/demo

显示相对于工作区根目录的相对目录。

$ git rev-parse --show-prefix
a/b/c

显示从当前目录(cd)后退(up)到工作区的根的深度。

$ git rev-parse --show-cdup
../../..

git rev-parse HEAD 获取当前最后一个的 commit hash

$ [master] git rev-parse HEAD
51834cc95f15c81b1d8c6afc2625e50a81aadb23

面命令中的HEAD可以替换成branch name,如git rev-parse dev获取dev分支的最后一次提交

git rev-parse --abbrev-ref HEAD获取当前分支名

$ [master] git rev-parse --abbrev-ref HEAD
master

上面命令都说是获取当前的XX,也就是说你运行命令时所在的 git 目录,如果在任何目录运行可以获取当前的XX,需要明确指出.git目录的位置以及git对应的工作目录。

$ git --git-dir='./maleskine/.git' rev-parse --abbrev-ref HEAD
master

通过设置--git-dir选项,也可以正确的获取到maleskine项目当前的分支名。git还有一个选项--work-tree可以指定git的工作目录。

7. git reset

git reset --hard logid(logid的前几位即可)  --将版本库还原到历史的某个时刻的状态
git reset --hard HEAD^ --将版本库还原到上一次commit之前的状态
#有时候,进行了错误的提交,但是还没有push到远程分支,想要撤销本次提交,可以使用git reset –-soft/hard命令。
git reset –-soft:回退到某个版本,只回退了commit的信息,代码修改过的没变。如果还要提交,直接commit即可;
git reset -–hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容,撤销的commit中所包含的更改被冲掉,即commit与修改过代码都撤销,变为原来的某个版本;

8. git config

git config --global user.name 'username' --添加版本库的用户名到本地配置文件
git config --global user.emal 'emal' --添加版本库的用户邮箱到本地配置文件

9. git diff

执行 git diff 来查看执行 git status 的结果的详细信息。

git diff 命令显示已写入缓存与已修改但尚未写入缓存的改动的区别

尚未缓存的改动:

git diff

查看已缓存的改动:

git diff --cached

查看已缓存的与未缓存的所有改动:

git diff HEAD

显示摘要而非整个 diff:

git diff --stat

实例;

git status -s
git diff
git add hello.php
git status -s
git diff --cached

10. git commit

git commit -m 'test comment from w3cschool.cn'
git add 提交缓存的流程太过繁琐,Git 也允许你用 -a 选项跳过这一步
git commit -am 'changes to hello file'
git commit --signoff -m 'xxx'    // 表示提交的信息中带有署名信息;
git commit --amend 'xxx'   // 表示对上一次提交的信息,进行修改提交;

11 git rm

git rm 将文件从缓存区中移除
git rm hello.php 
git rm file 会将文件从缓存区和你的硬盘中(工作目录)删除。 如果要在工作目录中留着该文件
git rm --cached

12 git log

git log 查看提交历史
git log --oneline            --oneline 选项来查看历史记录的简洁的版本
git log --oneline --graph    -graph 选项,查看历史中什么时候出现了分支、合并。
git log --reverse --oneline  '--reverse'参数来逆向显示所有日志
git log --author=Linus --oneline -5   --author , 例如,比方说我们要找 Git 源码中 Linus 提交的部分
git log --oneline --before={3.weeks.ago} --after={2010-04-18} --no-merges

13 git tag

git tag  #查看所有标签

-a 选项意为"创建一个带注解的标签"。 不用 -a 选项也可以执行的,但它不会记录这标签是啥时候打的,谁打的,也不会让你添加个标签的注解

git tag -a v1.0
git log --oneline --decorate --graph     --decorate 时,我们可以看到我们的标签

追加标签

git tag -a v0.9 85fc7e7
git log --oneline --decorate --graph

指定标签信息命令:

git tag -a <tagname> -m "w3cschool.cn标签"

PGP签名标签命令:

git tag -s <tagname> -m "w3cschool.cn标签"
相关文章
|
2月前
|
开发工具 git
git 常用命令
这些只是 Git 命令的一部分,Git 还有许多其他命令和选项,可根据具体需求进行深入学习和使用。熟练掌握这些命令能够帮助你更高效地管理代码版本和协作开发。
|
5月前
|
存储 开发工具 git
|
1月前
|
机器学习/深度学习 Shell 网络安全
【Git】Git 命令参考手册
Git 命令参考手册的扩展部分,包含了从基础操作到高级功能的全面讲解。
38 3
|
5月前
|
开发工具 git
【GIT 第二篇章】GIT常用命令
Git常用命令涵盖初始化、状态管理、提交、分支处理、远程操作等关键流程。`git init`启动本地仓库,`git clone`下载远程仓库。通过`git status`和`git diff`检查工作状态与差异。利用`git add`暂存文件,`git commit`保存更改。借助`git branch`、`git checkout`、`git merge`和`git rebase`管理分支。使用`git fetch`、`git pull`和`git push`同步远程仓库。通过`git reset`、`git revert`和`git checkout`实现版本回退。
79 0
|
2月前
|
缓存 Java Shell
[Git]入门及其常用命令
本文介绍了 Git 的基本概念和常用命令,包括配置、分支管理、日志查看、版本回退等。特别讲解了如何部分拉取代码、暂存代码、删除日志等特殊需求的操作。通过实例和图解,帮助读者更好地理解和使用 Git。文章强调了 Git 的细节和注意事项,适合初学者和有一定基础的开发者参考。
60 1
[Git]入门及其常用命令
|
3月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
153 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
2月前
|
开发工具 git 开发者
|
2月前
|
开发工具 git 开发者
提升Git效率:掌握这5个高级命令
【10月更文挑战第17天】
72 0
|
4月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
无论团队项目还是个人开发,掌握 Git 命令都是必备技能。本文介绍 Git 的基本概念与命令,如初始化仓库 (`git init`)、添加文件 (`git add`)、提交更改 (`git commit`)、检出分支 (`git checkout`)、合并分支 (`git merge`) 等,还分享了高级技巧如查看差异 (`git diff`)、撤销提交 (`git revert`)、修复合并冲突 (`git mergetool`) 和使用别名简化命令 (`git config --global alias.ci commit`)。
|
4月前
|
机器学习/深度学习 Shell 开发工具
Python使用管道执行git命令报错|4-7
Python使用管道执行git命令报错|4-7