Git 完整操作之记录
目录
一 . Git 基本操作流程及示例代码
1. 初始化 Git 仓库
2. 克隆远程仓库
3. 检查当前状态
4. 添加文件到暂存区
5. 提交更改
6. 查看提交历史
7. 创建分支
8. 切换分支
9. 合并分支
10. 推送更改到远程仓库
11. 拉取远程仓库的更改
12. 回滚到上一个版本
二 . .gitignore 过滤
1. 基本语法
(1) 忽略文件夹:
(2) 忽略文件:
(3) 忽略某类型文件:
(4) 忽略特定路径的文件或文件夹:
(5) 忽略某一文件夹下的某类型文件:
2. 添加 .gitignore 文件到 Git 仓库
(1)创建或编辑 .gitignore 文件: 在项目的根目录创建 .gitignore 文件,或者编辑现有的 .gitignore 文件。
(2)将 .gitignore 文件添加到 Git 仓库:
(3)移除已被跟踪的文件或文件夹
(4)示例
一 . Git 基本操作流程及示例代码
以下是一个完整的 Git 基本操作流程和示例代码,包含常见的 Git 命令及其使用示例。
git add .git commit -m '提交数据'git pull origin devgit push origin dev
1. 初始化 Git 仓库
如果您还没有 Git 仓库,可以使用以下命令初始化一个新的 Git 仓库:
git init
例如,在当前目录中初始化一个新的 Git 仓库:
mkdir myproject cd myproject git init
2. 克隆远程仓库
如果您要克隆一个现有的远程仓库,可以使用以下命令:
mkdir myproject cd myproject git init
例如,克隆一个 GitHub 仓库:
git clone https://github.com/user/repository.git
3. 检查当前状态
查看工作目录和暂存区的当前状态:
git status
4. 添加文件到暂存区
git add . 和 git add * 区别
git add . 会把本地所有untrack的文件都加入暂存区,并且会根据.gitignore做过滤git add * 会忽略.gitignore把任何文件都加入
将文件添加到暂存区以便提交:
git add <file-name>
例如,添加一个名为 example.txt 的文件:
git add example.txt
添加所有文件:
git add .
5. 提交更改
将暂存区的更改提交到本地仓库:
git commit -m "Your commit message"
6. 查看提交历史
git log
7. 创建分支
git branch <branch-name>
例如,创建一个名为 feature-branch 的新分支:
git branch feature-branch
8. 切换分支
切换到另一个分支:
git checkout <branch-name>
例如,切换到 feature-branch 分支:
git checkout feature-branch
或者创建并切换到新分支:
git checkout feature-branch
例如:
git checkout -b new-feature
9. 合并分支
将另一个分支合并到当前分支:
git merge <branch-name>
例如,将 feature-branch 分支合并到当前分支:
git merge feature-branch
10. 推送更改到远程仓库
将本地分支推送到远程仓库:
git push origin <branch-name>
例如,将 feature-branch 分支推送到远程:
git push origin feature-branch
11. 拉取远程仓库的更改
从远程仓库拉取最新更改并合并到当前分支:
git pull
从特定分支拉取并合并:
git pull origin <branch-name>
例如,从 main 分支拉取并合并:
git pull origin main
12. 回滚到上一个版本
查看提交历史:
git log
找到目标提交哈希后,回滚到该提交:
git checkout <commit-hash>
例如,回滚到特定提交:
git checkout 1a2b3c4d
硬重置到特定提交(警告:会丢失之后的更改):
git reset --hard <commit-hash>
例如:
git reset --hard 1a2b3c4d
二 . .gitignore 过滤
在 Git 中,使用 .gitignore 文件来过滤掉不想被跟踪的文件和文件夹
下面是一些常见的 .gitignore 文件的用法和示例规则。
1. 基本语法
(1) 忽略文件夹:
/folder_name/
忽略项目根目录中的 folder_name 文件夹及其所有内容。
(2) 忽略文件:
filename.ext
忽略项目中的所有 filename.ext 文件。
(3) 忽略某类型文件:
*.ext
忽略项目中的所有 .ext 文件。
(4) 忽略特定路径的文件或文件夹:
/path/to/folder/
/path/to/file.ext
忽略指定路径中的文件或文件夹。
(5) 忽略某一文件夹下的某类型文件:
folder_name/*.ext
忽略 folder_name 文件夹中的所有 .ext 文件。
(6) 示例 .gitignore 文件
以下是一个示例 .gitignore 文件,其中包含了一些常见的过滤规则:
# Node.js
node_modules/
npm-debug.log*
yarn-debug.log*
yarn-error.log*# Python
__pycache__/
*.py[cod]
*.egg-info/
*.egg
*.pyo# Java
*.class
*.jar
*.war
*.ear# Logs
logs/
*.log# OS generated files
.DS_Store
Thumbs.db# IDEs and editors
.idea/
.vscode/
*.swp# Compiled source
*.com
*.class
*.dll
*.exe
*.o
*.so# Static folder
/static/# Ignore specific configuration files
config/local_settings.py
2. 添加 .gitignore 文件到 Git 仓库
(1)创建或编辑 .gitignore 文件: 在项目的根目录创建 .gitignore 文件,或者编辑现有的 .gitignore 文件。
(2)将 .gitignore 文件添加到 Git 仓库:
git add .gitignore
git commit -m "添加 .gitignore 文件"
git push origin <your-branch-name>
(3)移除已被跟踪的文件或文件夹
如果某些文件或文件夹已经被 Git 跟踪,需要先将它们从 Git 的索引中移除,然后再提交更改:
git rm -r --cached <path_to_file_or_folder>
git commit -m "移除已跟踪的文件或文件夹"
git push origin <your-branch-name>
(4)示例
假设您想要忽略 static、.idea 和 __pycache__ 文件夹,并且这些文件夹已经被跟踪了,可以按照以下步骤操作:
-
更新
.gitignore文件:/static/ /.idea/ /__pycache__/ -
移除这些文件夹的跟踪:
git rm -r --cached static git rm -r --cached .idea git rm -r --cached __pycache__ -
提交更改:
git add .gitignore git commit -m "删除并忽略 static、.idea 和 __pycache__ 文件夹" git push origin <your-branch-name>
这样可以确保这些文件夹在未来的操作中被 Git 忽略,并且不会再被添加到仓库中。
相关文章:
Git 完整操作之记录
目录 一 . Git 基本操作流程及示例代码 1. 初始化 Git 仓库 2. 克隆远程仓库 3. 检查当前状态 4. 添加文件到暂存区 5. 提交更改 6. 查看提交历史 7. 创建分支 8. 切换分支 9. 合并分支 10. 推送更改到远程仓库 11. 拉取远程仓库的更改 12. 回滚到上一个版本 二…...
mediaPlayer的内存泄露解决方法
MediaPlayer在Android中用于播放音频和视频。如果不正确管理,MediaPlayer可能会导致内存泄漏,尤其是当它被用于多个Activity或长时间播放时。以下是一些解决MediaPlayer内存泄漏的方法: ### 1. 及时释放资源 当MediaPlayer不再使用时&#x…...
delphi3层 delphi 3层
一、为DataSnap系统服务程序添加描述 procedure TServerContainer.ServiceAfterInstall(Sender: TService); var reg: TRegistry; begin reg : TRegistry.Create; try with reg do begin RootKey : HKEY_LOCAL_MACHINE; if OpenKey(SYSTEM/CurrentC…...
Python编程学习第一篇——制作一个小游戏休闲一下
到上期结束,我们已经学习了Python语言的基本数据结构,除了数值型没有介绍,数值型用的非常广,但也是最容易理解的,将在未来的学习中带大家直接接触和学习掌握。后续我们会开始学习这门语言的一些基础语法和编程技巧&…...
03--nginx架构实战
前言:这应该是nginx梳理的最后一章,写一些关于网站架构和网站上线的知识内容,主要是感觉到运维并不是单一方向的行业,这一章概念会有一些广泛,但是非常重要,都是这几年工作中遇到的情况,整理一下…...
【力扣第 400 场周赛】Leetcode 删除星号以后字典序最小的字符串
文章目录 1. 删除星号以后字典序最小的字符串 1. 删除星号以后字典序最小的字符串 题目链接 🍎 解题思路:遇到 *就删除一个字符,为了满足题意,要删除字典序最小的字符,那么假如有多个字典序最小的字符我们该删除哪个…...
Unity DOTS技术(九) BufferElement动态缓冲区组件
文章目录 一.简介二.例子 一.简介 在之前的学习中我们发现Entity不能挂载相同的组件的. 当我们需要用相同的组件时则可以使用.IBufferElementData接口 动态缓冲区组件来实现 二.例子 1.创建IBufferElementData组件 using Unity.Entities; using UnityEngine; //[GenerateAu…...
hnust 湖南科技大学 2022 软件测试报告+代码
hnust 湖南科技大学 2022 软件测试报告代码 内容 BMI junit单元测试决策表划分方法测试三角形判断问题文档修改问题之因果图实验逻辑覆盖测试技术实验(白盒测试)selenium 功能自动化测试Jmeter 性能自动化测试 下载地址 https://pan.baidu.com/s/19e…...
【面试笔记】单片机软件工程师,工业控制方向(储能)
文章目录 1. 基础知识1.1 C语言笔试题1.1.1 用宏定义得到一个数组所含的元素个数1.1.2 定义函数指针从程序固定地址(0)开始执行1.1.3 volatile的含义及作用1.1.4 32位系统,整数7和-7,分别以大端和小端存储,请示意说明 1.2 嵌入式基础1.2.1 简…...
基于springboot实现小区团购管理系统项目【项目源码+论文说明】计算机毕业设计
基于springboot实现小区团购管理系统演示 摘要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装小区团购管理软件来…...
基于django | 创建数据库,实现增、删、查的功能
1、在cmd中,输入指令进入mysql终端: mysql -u 用户名 -p 2、输入mysql的密码 3、输入指令,显示出所有的数据库 show databases; 4、输入指令创建表: create table 表名 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; 5、use …...
数据结构与算法07-图
介绍 图是一种善于处理关系型数据的数据结构,使用它可以很轻松地表示数据之间是如何关联的。 图的实现形式有很多,最简单的方法之一就是用散列表。 friends { "Alice" > ["Bob", "Diana", "Fred"], &quo…...
springboot项目部署需要redis集群问题
本来直接将redis为单独启动模式转为配置 yml文件 spring.redis.cluster.nodes: 192.168.12.78:8001,192.168.12.78:8002,192.168.12.78:8003, java文件 package io.sirc.config;import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.ann…...
JVMの内存泄漏内存溢出案例分析
1、内存溢出 内存溢出指的是程序在申请内存时,没有足够的内存可供分配,导致无法满足程序的内存需求,常见的内存溢出情况包括堆内存溢出(Heap Overflow)和栈溢出(Stack Overflow): …...
v31支架固定方式
CK_Label_v31 夹子固定方式 底座粘贴固定方式...
Jenkins从入门到精通面试题及参考答案(3万字长文)
目录 什么是Jenkins? Jenkins是如何工作的? Jenkins与持续集成(CI)有什么关系?...
如何使用电阻器?创建任何电阻的简单过程
您可能有一整盒E12 系列电阻器,但仍然无法获得足够接近您所需电阻的值。如果您需要 50 kΩ 电阻,接近的电阻是 47 kΩ。当然,这个误差在 10% 以内,但这对于您的应用程序来说可能还不够好。你会怎样做? 本文将介绍一个…...
学Python,看一篇就够
学Python,看一篇就够 python基础注释变量标识符命名规则使用变量认识bugDebug工具打断点 数据类型输出转义字符输入输入语法输入的特点 转换数据类型pycharm交互运算符的分类赋值运算符复合赋值运算符比较运算符逻辑运算符拓展 条件语句单分支语法多分支语法拓展 if…...
数据仓库核心:维度表设计的艺术与实践
文章目录 1. 引言1.1基本概念1.2 维度表定义 2. 设计方法2.1 选择或新建维度2.2 确定维度主维表2.3 确定相关维表2.14 确定维度属性 3. 维度的层次结构3.1 举个例子3.2 什么是数据钻取?3.3 常见的维度层次结构 4. 高级维度策略4.1 维度整合维度整合:构建…...
SQL实验 连接查询和嵌套查询
一、实验目的 1.掌握Management Studio的使用。 2.掌握SQL中连接查询和嵌套查询的使用。 二、实验内容及要求(请同学们尝试每道题使用连接和嵌套两种方式来进行查询,如果可以的话) 1.找出所有任教“数据…...
信号处理必看!CTFT/DTFT/DFT的三角关系图解与常见误区
信号处理必看!CTFT/DTFT/DFT的三角关系图解与常见误区 引言:为什么我们需要理解这三种变换的关系? 在数字信号处理的世界里,傅里叶变换家族就像是一把瑞士军刀,而CTFT(连续时间傅里叶变换)、DTF…...
华为eNSP实战:3种方法搞定VLAN间通信(附完整配置命令)
华为eNSP实战:VLAN间通信的3种工程化解决方案深度解析 刚接触企业级网络时,最让我困惑的就是不同部门间的网络隔离与互通问题。财务部的电脑为什么不能直接访问研发部的服务器?为什么同一个物理交换机下的设备会被划分到不同的广播域…...
基于三菱PLC和MCGS广场喷泉的系统:后发送产品包含梯形图、接线图与原理图等详细资料
基于三菱 plc和MCGS 广场喷泉 我们主要的后发送的产品有,带解释的梯形图接线图原理图图纸,io分配,组态画面最近刚折腾完一个广场喷泉的小项目,用的三菱FX3U PLC加MCGS触摸屏,本来就是冲着练手去的,结果搞…...
嵌入式轻量级日志框架:零堆内存与编译期级别控制
1. Logger库深度解析:面向嵌入式系统的轻量级串口日志框架 1.1 设计定位与工程价值 Logger库虽以“Arduino library”为标签,但其本质是一个面向资源受限嵌入式平台的 轻量级串口日志框架 。在STM32、ESP32、nRF52等主流MCU平台上,日志输出…...
2026届毕业生推荐的十大AI学术平台解析与推荐
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 对内容创作领域而言,降低AI生成文本的检测比率成了重要课题。其一,建…...
递归封神!二叉树两大究极考题:路径总和 III + 最近公共祖先|面试原地 AC
目录 前言 一、路径总和 III:任意起点、任意终点的路径计数 思路一句话总结 完整 AC 代码 关键点小白精讲 二、二叉树的最近公共祖先:后序遍历的神级应用 思路一句话总结 完整 AC 代码 小白秒懂逻辑 三、两道题核心思想总结 路径总和 III 最近…...
程序员副业全攻略:从技术到变现
CSDN程序员副业图谱技术文章大纲副业方向概览分析程序员常见的副业类型,包括技术咨询、外包开发、在线教育、自媒体运营、开源项目、技术写作等。技术咨询与外包开发探讨如何通过Freelancer平台(如Upwork、Fiverr)或国内外包平台(…...
Agent 的能力体系
提示词及其能力边界 在将 Agent 具体应用到实际的生产环境中之前,人们首先需要弄清楚的是:提示词在这类应用中的作用到底是什么?它的能力边界在哪里?如果我们在这两个问题上的理解出现了偏差,那么后续所有针对 Agent …...
Python程序设计强基计划10讲 · 第三讲:字典与集合——哈希表的威力
Python程序设计强基计划10讲 第三讲:字典与集合——哈希表的威力作者:培风图南以星河揽胜 发布时间:2026年3月31日 适用对象:已掌握列表、元组等序列类型的Python初学者 前置知识:第二讲《列表与元组——序列操作的艺…...
告别打包噩梦:用PyInstaller一键搞定Rasterio等‘顽固’依赖的终极配置
告别打包噩梦:用PyInstaller一键搞定Rasterio等‘顽固’依赖的终极配置 打包Python项目时遇到ModuleNotFoundError几乎是每个开发者的必经之路,尤其是当项目依赖像Rasterio这样包含C扩展和复杂文件结构的库时。传统的临时解决方案——手动添加hiddenimp…...
