首页 > 其他分享 >git 常见操作

git 常见操作

时间:2024-04-11 21:24:29浏览次数:29  
标签:origin git log 仓库 常见 提交 操作 分支

1、第一次初始化

  • git init
    git add .
    git commit -m ‘first commit’
    git remote add origin git@github.com:帐号名/仓库名.git
    git pull origin master
    git push origin master # -f 强推
  • git clone git@github.com:git帐号名/仓库名.git

2、工作基本操作

  • git checkout master 切到主分支
  • git fetch origin 获取最新变更
  • git checkout -b dev origin/master 基于主分支创建dev分支
  • git add . 添加到缓存
  • git commit -m ‘xxx’ 提交到本地仓库
  • git fetch origin 获取最新变更

3、初始化仓库

git init

4、查看仓库当前状态

git status

5、文件相关操作

将文件添加到仓库:

  • git add 文件名 将工作区的某个文件添加到暂存区
  • git add . 将当前工作区的所有文件都加入暂存区
  • git add -u 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件
  • git add -A 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件
  • git add -i 进入交互界面模式,按需添加文件到缓存区

将暂存区文件提交到本地仓库:

  • git commit -m “提交说明” 将暂存区内容提交到本地仓库
  • git commit -a -m “提交说明” 跳过缓存区操作,直接把工作区内容提交到本地仓库

比较文件异同

  • git diff 工作区与暂存区的差异
  • git diff 分支名 工作区与某分支的差异,远程分支这样写:remotes/origin/分支名
  • git diff HEAD 工作区与HEAD指针指向的内容差异
  • git diff 提交id 文件路径 工作区某文件当前版本与历史版本的差异
  • git diff –stage 工作区文件与上次提交的差异(1.6 版本前用 –cached)
  • git diff 版本TAG 查看从某个版本后都改动内容
  • git diff 分支A 分支B 比较从分支A和分支B的差异(也支持比较两个TAG)
  • git diff 分支A…分支B 比较两分支在分开后各自的改动

另外:如果只想统计哪些文件被改动,多少行被改动,可以添加 –stat 参数

6、查看历史记录

  • git log 查看所有commit记录(SHA-A校验和,作者名称,邮箱,提交时间,提交说明)
  • git log -p -次数 查看最近多少次的提交记录
  • git log –stat 简略显示每次提交的内容更改
  • git log –name-only 仅显示已修改的文件清单
  • git log –name-status 显示新增,修改,删除的文件清单
  • git log –oneline 让提交记录以精简的一行输出
  • git log –graph –all –online 图形展示分支的合并历史
  • git log –author=作者 查询作者的提交记录(和grep同时使用要加一个–all–match参数)
  • git log –grep=过滤信息 列出提交信息中包含过滤信息的提交记录
  • git log -S查询内容 和–grep类似,S和查询内容间没有空格
  • git log fileName 查看某文件的修改记录

7、代码回滚

  • git reset HEAD^ 恢复成上次提交的版本
  • git reset HEAD^^ 恢复成上上次提交的版本,就是多个^,以此类推或用~次数
  • git reflog
  • git reset –hard 版本号
  • –soft:只是改变HEAD指针指向,缓存区和工作区不变;
  • –mixed:修改HEAD指针指向,暂存区内容丢失,工作区不变;
  • –hard:修改HEAD指针指向,暂存区内容丢失,工作区恢复以前状态;

8、版本库相关操作

  • 删除版本库文件:git rm 文件名
  • 版本库里的版本替换工作区的版本:git checkout — test.txt

9、远程仓库相关操作

同步远程仓库:git push -u origin master

本地仓库内容推送到远程仓库:git remote add origin git@github.com:帐号名/仓库名.git

从远程仓库克隆项目到本地:git clone git@github.com:git帐号名/仓库名.git

查看远程库信息:git remote

拉取远程分支到本地仓库:

  • git checkout -b 本地分支 远程分支 # 会在本地新建分支,并自动切换到该分支
  • git fetch origin 远程分支:本地分支 # 会在本地新建分支,但不会自动切换,还需checkout
  • git branch –set-upstream 本地分支 远程分支 # 建立本地分支与远程分支的链接

同步远程仓库更新::git fetch origin master

10、分支相关操作

创建分支:git checkout -b dev -b表示创建并切换分支
上面一条命令相当于一面的二条:
git branch dev 创建分支
git checkout dev 切换分支

查看分支:git branch

合并分支:

  • git merge dev #用于合并指定分支到当前分支
  • git merge –no-ff -m “merge with no-ff” dev #加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并

删除分支:git branch -d dev

查看分支合并图:git log –graph –pretty=oneline –abbrev-commit

11、git相关配置

安装完Git后第一件要做的事,设置用户信息(global可换成local在单独项目生效):

  • git config –global user.name “用户名” # 设置用户名
  • git config –global user.email “用户邮箱” #设置邮箱
  • git config –global user.name # 查看用户名是否配置成功
  • git config –global user.email # 查看邮箱是否配置

12、其他查看配置相关

  • git config –global –list # 查看全局设置相关参数列表
  • git config –local –list # 查看本地设置相关参数列表
  • git config –system –list # 查看系统配置参数列表
  • git config –list # 查看所有Git的配置(全局+本地+系统)
  • git config –global color.ui true //显示git相关颜色

13、撤消某次提交

  • git revert HEAD # 撤销最近的一个提交
  • git revert 版本号 # 撤销某次commit

14、标签

  • git tag 标签 //打标签命令,默认为HEAD
  • git tag //显示所有标签
  • git tag 标签 版本号 //给某个commit版本添加标签
  • git show 标签 //显示某个标签的详细信息

拓展阅读

什么是git

Git(读音为/gɪt/)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。

Git 是基于 Linux内核开发的版本控制工具。与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持(wingeddevil注:这得分是用什么样的服务端,使用http协议或者git协议等不太一样。并且在push和pull的时候和服务器端还是有交互的。),使源代码的发布和交流极其方便。 Git 的速度很快,这对于诸如 Linux kernel 这样的大项目来说自然很重要。 Git 最为出色的是它的合并跟踪(merge tracing)能力。

标签:origin,git,log,仓库,常见,提交,操作,分支
From: https://www.cnblogs.com/wsxnihao/p/18130043

相关文章

  • RHCE常见的报错问题
    1:模块的参数报错的问题 上面的报错的原因只用看,Unsupported这里,后面说不支持这个enabeld这个参数,支持后面的这些参数 2:单位的问题 就是创建逻辑卷的的单位为m或者g不能是MiB的单位,这个单位是创建分区的单位 ......
  • python操作Excel
    windows/linux安装openpyxlpipinstallopenpyxl 查找某Excel中是否存在某字符串text#输入:#file_path:Excel文件名#search_text:要查找的字符串#输出:#查到:[sheetname,cell.row,cell.column]组成的数组#未查到:Nonedeffind_text_in_ex......
  • selenium之鼠标键盘操作
    selenium之鼠标键盘操作一、鼠标1、导包:fromselenium.webdriver.common.action_chainsimportActionChains2、常规操作2.1左键单击search_ele=WebDriverWait(driver,15,0.5).until(EC.visibility_of_element_located(("id","search-input")))search_ele.send_k......
  • 如何将自己的SpringBoot项目上传到GitHub上面!
    我最近想把之前做过的一些Java项目上传到GitHub上面,在网上找教程,失败了很多次终于完成了,先将方法介绍给大家!对了,先确保自己电脑装git了!!下载地址(镜像站下载快):https://mirrors.tuna.tsinghua.edu.cn/github-release/git-for-windows/git/LatestRelease/选择自己的电脑版本,一......
  • 关于git的上传远程仓库的常用命令总结
    我一般上传的步骤:(注意在那个文件夹下打开你要传送的项目)(1)gitinit(2)gitadd.(3)gitcommit-m"上传的项目"(4)与你需要的仓库建立连接gitremoteaddorigin(SSH/HTTPS)(5)gitpush-uoriginmaster/main出现发现远程仓库需要删除的文件下如何进行修改.........
  • Microsoft Wi-Fi Direct Virtual Adapter 是 Windows 操作系统中的一个虚拟网络适配器
    MicrosoftWi-FiDirectVirtualAdapter是Windows操作系统中的一个虚拟网络适配器,用于支持Wi-FiDirect功能。Wi-FiDirect是一种无需基础设施的连接技术,允许支持Wi-Fi的设备之间直接进行点对点连接,无需通过传统的Wi-Fi路由器或接入点。作用:直连功能: MicrosoftWi-......
  • Robocopy是Windows操作系统中的一个命令行实用工具,用于在文件和目录之间进行复制。它
    robocopy/?-------------------------------------------------------------------------------  ROBOCOPY  ::  Windows的可靠文件复制------------------------------------------------------------------------------- 开始时间:2024年4月11日16:33:......
  • Copy、Xcopy和Robocopy是Windows操作系统中用于文件和目录复制的命令行工具,它们在功能
    Copy、Xcopy和Robocopy是Windows操作系统中用于文件和目录复制的命令行工具,它们在功能和特性上有所不同:Copy:基本复制工具:Copy命令是Windows中最基本的文件复制工具之一,它允许将一个或多个文件从一个位置复制到另一个位置。简单操作:Copy命令适用于简单的文件复制操作,但它不提......
  • 肖sir__jmeter之操作数据库
    jmeter之操作数据库==========================一、下载jdbc驱动,安装jdbc驱动  2、将驱动存放在4个路径下(1)C:\ProgramFiles\Java\jre1.8.0_60\lib    (2)第二个存放的包C:\ProgramFiles\Java\jre1.8.0_60\lib\ext  (3)第三个存放的包  (4)存放第四个包......
  • 如何提交代码到gitee
    1首先是gitee的设置。   创建好了。    2然后是虚拟机的设置。        已经提交上来了。 使用了-f提交代码之后,可以看到之前在gitee上的readme文件已经没有了。 ......