日常开发中常用的git操作命令和使用技巧
wptr33 2025-05-26 19:22 10 浏览
日常开发中常用的git操作命令,从配置、初始化本地仓库到提交代码的常用git操作命令
使用git前的配置
刚使用git,先要在电脑上安装好git,接着我们需要配置一下帐户信息:用户名和邮箱。
# 设置用户名
git config --global user.name "xxx"
# 设置邮箱
git config --global user.email "xxx"
- global:对当前用户所有仓库有效
- local:只对当前仓库有效
- system:对系统所有登录的用户有效
查看配置信息
git config --list --global
初始化一个本地仓库
配置好后就可以初始化一个本地仓库
git init
同时我们也可以针对仓库进行账户信息配置,如果要清除配置可以用下面的命令
git config --unset --local user.name
git clone克隆远程仓库代码
初始化好仓库后我们就可以用git clone拉去远程仓库的代码
git clone xxx
接着可以进入的代码目录下,默认拉取到的是master分支,这时可以用git checkout切换到自己的开发分支
# 切换到某个分支
git checkout feat-zhou
# 想要拉取最新代码
git pull
git banch
正常开发中用到的开发分支,一般会在其他需求管理平台上统一创建,但有时我们也需要自己在本地创建分支。
# 基于当前分支创建分支
git branch feat-test
# 查看本地的分支
git branch
# 删除本地的dev分支
git branch -D dev
工作区、暂存区和远程仓库
这一部份是我们日常开发中使用最频繁的地方,git有3种状态:已修改、已暂存和已提交,一个文件我们在工作区修改了代码就会变成已修改,此时可以查看本地修改的状态
git status
然后可以将本地的修改添加到暂存区
# 添加单个文件到暂存区
git add <file>
# 添加多个文件到暂存区
git add <file>
# 添加所有修改和新增的文件到暂存区,注意不包括删除的文件
git add .
# 从工作区和暂存区删除某个文件
git rm <file>
等开发完成后我们就可以将代码提交到远程仓库
# 将暂存区的所有修改会生成一条记录,添加个方便我们后续查找的备注
git commit -m "feat:新增用户登录接口"
# 推送到远程仓库
git push
git merge
有时需要往某个分支合代码时,比如开发完成提测时往test测试环境分支合代码,我们就需要用到merge命令。
# 先切换到test分支
git checkout test
# 拉取最新代码
git pull
# 将开发分支代码合到test分支
git merge feat-zhou
# 推送到远程仓库
git add .
git commit -m "merge feat-zhou"
git push
注意如果上面merge后有冲突时,这时就需要自己先在本地解决完冲突后,才能推送到远程分支
# 标记冲突已解决
git add .
# 推送到远程仓库
git commit -m "merge feat-zhou"
git push
git stash
当我们开发中跟别人共用了同一个分支开发,然后别人突然提交了代码,这个时候我们就可以用git stash把本地的修改暂存起来,然后git pull拉取到最新的代码,再把git stash中存的代码添加进来。
还有就是开发中线上突然出现了bug,需要先切换到其他分支去解决问题,但是当前分支的代码可能我们还没写好还不想提交,这时我们也可以通过git stash暂存起来。
# 查看本地 stash 暂存过的所有记录
git stash list
# 暂存本地修改
git stash save "xxx"
# 将最近一次暂存修改的代码加载回来
git stash apply
# 将最近一次暂存修改的代码加载回来,并删掉暂存记录
git stash pop
给某个已经提交过的文件重命名
当我们在开发中需要修改某个文件的路径时,比如之前放的目录不合理需要移到另一个目录下,直接将文件拖到新的目录后提交svn时实际会是两步操作,之前目录的文件先被删除,然后在新的目录下添加了一个新的文件。
这就会导致新目录下文件之前的提交记录丢失了,因为对git来说这是一个新增的文件。
这种情况其实我们就可以用git mv命令来解决,不管是移动目录还是修改文件名,文件所有之前的提交记录都不会丢失。
# 重命名文件
git mv xx xx
清屏
# Mac
clear
# Windows
cls
git log
通过git log命令可以查看历史提交的记录
# 查看所有提交记录,可以详细看到提交人、提交日期这些,也可以不加 --all
git log --all
# 以简洁方式查看提交记录,每条记录只会占用一行显示提交id和备注信息
git log --oneline
# 查看最近4条
git log -n 4
# 简洁方式查看最近4条
git log --oneline -n 4
git批量删除本地分支
开发一段时间后,我们本地会有很多无用的分支,一个一个的 git branch -D branchName 又感觉太费时间了,如果要批量删除,可以用下面的命令:
git checkout master
git branch | grep -v 'master' | xargs git branch -D
注:以上命令只能用 Git Bash 运行才有效,直接在终端命令、PowerShell、vscode终端里运行都会报错:无法识别 grep(windows cmd 终端切换到D盘:① cd /d d:② d:)
具体执行步骤是:
1、切换到master分支,因为当前的分支不能删除,要保留哪个就先切换到哪个分支
2、将git branch的结果进行筛选,除去master分支
3、将处理后的结果作为git branch -D的参数来进行批量删除
grep 查找命令
- grep name 表示查看包含name这个关键字的内容
- grep -v name 反向查找,表示查看除了含有name之外的内容
xargs
xargs(英文全拼: eXtended ARGuments),是给命令传递参数的一个过滤器,也是组合多个命令的一个工具
管道命令符
管道命令符 | 的作用是将前一个命令的标准输出当作后一个命令的标准输入,格式为“命令A|命令B"
- 上一篇:macOS更新后Git无法使用的解决办法
- 下一篇:如何获取Git中当前提交的哈希值
相关推荐
- Python自动化脚本应用与示例(python办公自动化脚本)
-
Python是编写自动化脚本的绝佳选择,因其语法简洁、库丰富且跨平台兼容性强。以下是Python自动化脚本的常见应用场景及示例,帮助你快速上手:一、常见自动化场景文件与目录操作...
- Python文件操作常用库高级应用教程
-
本文是在前面《Python文件操作常用库使用教程》的基础上,进一步学习Python文件操作库的高级应用。一、高级文件系统监控1.1watchdog库-实时文件系统监控安装与基本使用:...
- Python办公自动化系列篇之六:文件系统与操作系统任务
-
作为高效办公自动化领域的主流编程语言,Python凭借其优雅的语法结构、完善的技术生态及成熟的第三方工具库集合,已成为企业数字化转型过程中提升运营效率的理想选择。该语言在结构化数据处理、自动化文档生成...
- 14《Python 办公自动化教程》os 模块操作文件与文件夹
-
在日常工作中,我们经常会和文件、文件夹打交道,比如将服务器上指定目录下文件进行归档,或将爬虫爬取的数据根据时间创建对应的文件夹/文件,如果这些还依靠手动来进行操作,无疑是费时费力的,这时候Pyt...
- python中os模块详解(python os.path模块)
-
os模块是Python标准库中的一个模块,它提供了与操作系统交互的方法。使用os模块可以方便地执行许多常见的系统任务,如文件和目录操作、进程管理、环境变量管理等。下面是os模块中一些常用的函数和方法:...
- 21-Python-文件操作(python文件的操作步骤)
-
在Python中,文件操作是非常重要的一部分,它允许我们读取、写入和修改文件。下面将详细讲解Python文件操作的各个方面,并给出相应的示例。1-打开文件...
- 轻松玩转Python文件操作:移动、删除
-
哈喽,大家好,我是木头左!Python文件操作基础在处理计算机文件时,经常需要执行如移动和删除等基本操作。Python提供了一些内置的库来帮助完成这些任务,其中最常用的就是os模块和shutil模块。...
- Python 初学者练习:删除文件和文件夹
-
在本教程中,你将学习如何在Python中删除文件和文件夹。使用os.remove()函数删除文件...
- 引人遐想,用 Python 获取你想要的“某个人”摄像头照片
-
仅用来学习,希望给你们有提供到学习上的作用。1.安装库需要安装python3.5以上版本,在官网下载即可。然后安装库opencv-python,安装方式为打开终端输入命令行。...
- Python如何使用临时文件和目录(python目录下文件)
-
在某些项目中,有时候会有大量的临时数据,比如各种日志,这时候我们要做数据分析,并把最后的结果储存起来,这些大量的临时数据如果常驻内存,将消耗大量内存资源,我们可以使用临时文件,存储这些临时数据。使用标...
- Linux 下海量文件删除方法效率对比,最慢的竟然是 rm
-
Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...
- Python 开发工程师必会的 5 个系统命令操作库
-
当我们需要编写自动化脚本、部署工具、监控程序时,熟练操作系统命令几乎是必备技能。今天就来聊聊我在实际项目中高频使用的5个系统命令操作库,这些可都是能让你效率翻倍的"瑞士军刀"。一...
- Python常用文件操作库使用详解(python文件操作选项)
-
Python生态系统提供了丰富的文件操作库,可以处理各种复杂的文件操作需求。本教程将介绍Python中最常用的文件操作库及其实际应用。一、标准库核心模块1.1os模块-操作系统接口主要功能...
- 11. 文件与IO操作(文件io和网络io)
-
本章深入探讨Go语言文件处理与IO操作的核心技术,结合高性能实践与安全规范,提供企业级解决方案。11.1文件读写11.1.1基础操作...
- Python os模块的20个应用实例(python中 import os模块用法)
-
在Python中,...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)