【Git】上传本地文件到Git(以Windows环境为例)

news2024/10/5 18:31:06

Git 的下载参考:Git 安装及配置

一、Git 上传的整体流程

1、工作区 => 本地仓库

将本地文件上传到Git,需要先上传到本地仓库,然后再上传到远程仓库。要上传文件到本地仓库,不是直接拷贝进去的,而是需要通过命令一步步上传。从工作区到本地仓库分为了三步,也可以说是三个区域:

① 工作区

我们要上传的文件所处位置,一般称为“工作区”,工作区是开发者直接编辑和修改文件的地方,包括源代码、配置文件等。

② 暂存区

暂存区用于暂时存储待提交的修改文件,暂存区的存在允许开发者在提交前对修改的文件进行审核。此外,暂存区允许将相关修改进行逻辑分组,开发者可以将同一部分修改的文件添加到暂存区,形成一个逻辑上的组,方便开发者管理和提交相关的修改。

③ 本地仓库

本地仓库记录了项目从创建开始的所有修改、提交和版本信息,通过本地仓库,开发者可以追踪、查看和恢复之前的任何版本,包括历史各个版本的备份。此外,本地仓库支持分支操作,开发者可以创建、切换和合并不同的分支。

2、本地仓库 => 远程仓库

为了可以让其他用户看到自己的成果,我们可以将自己本地仓库的内容上传到远程仓库;如果我们希望借鉴其他用户的成果,我们可以将远程仓库里的一些内容拉取或者克隆到本地仓库。

二、工作区 到 本地仓库

1、建立本地仓库(git init)

使用 git init 来建立一个本地仓库,该命令将当前目录转换为一个 git 仓库,并在该仓库中跟踪新的或已有的文件。如果当前目录下出现了 .git 目录,说明本地仓库建立成功。

2、工作区—暂存区(git add)

使用 git add 将工作区的内容添加到暂存区,可以搭配 .gitignore 文件使用。Windows 的默认换行符是回车(CR)+换行(LF)即'\r\n',而Linux环境的默认换行符是换行(LF)即'\n'。针对不同环境,在操作之间,输入如下命令

# Windows 环境
#提交时转换为LF,拉取时转换为CRLF
git config --global core.autocrlf true

# Linux 环境
#提交时转换为LF,拉取时不转换
git config --global core.autocrlf input

创建 .gitignore 文件(可跳过)

 默认情况下,Git会管理工作区的所有文件,然而对于一些临时文件,我们不希望Git 来管理,此时我们可以在 .gitignore 文件中加入要忽略的目录或者文件,.gitignore 文件的写法如下。(若没有要忽略的文件,可以直接使用 git add)

# 忽略所有的 .a 文件
*.a

# 忽略 build 目录下的所有文件
build/

# 忽略build 目录下的所有 .txt 文件,注意 build/doc/ 下的 .txt 文件不会被忽略
build/*.txt

# 忽略build目录以及子目录下的所有 .txt 文件
build/**/*.txt

git add 将文件拷贝到暂存区

只要还没提交到本地仓库,我们可以多次上传文件到暂存区。 

# 命令格式: git add <file1> <file2> ...
# 将当前目录下的file.txt 上传至暂存区
git add file.txt

# 将当前目录下所有的文件上传至暂存区
git add . 

可以使用 git status 命令查看工作区和暂存区之间的状态,它会列出有关工作区和暂存区的文件的当前状态信息,例如已修改、已暂存等。一旦commit,git status 保存的修改就会被清空。

3、暂存区—本地仓库(git commit)

git commit 表示提交一条上传记录到本地仓库,同时为该条记录分配ID,有了ID我们就可以进行版本回溯,提交时可以携带提交信息,即本次提交做出了哪些修改。

# 命令格式: git commit -m "提交信息"
git commit -m "first commit"

随后可以输入 git log 来查看提交历史,它会显示当前分支的所有提交记录,包括提交者、提交时间、提交的信息等。

注意:如果是直接输入 git commit,则会弹出编辑器让你输入提交信息,使用方法类似于Linux环境下的vi编辑器。

三、本地仓库 到 远程仓库

要将本地仓库的内容上传到远程仓库,最终需要使用 git push 来上传,git push 的命令格式如下。

git push [-f] [--set-upstream] [远程仓库名] [本地分支名][:远程仓库的分支名]
  • 远程仓库名:可以是url,也可以是远程仓库在本地的别名
  • 远程分支名:可省略,省略的情况下和本地分支名一致
  • -f : 本地内容强制覆盖远端内容(一般不使用)
  • --set-upstream: 推送到远端的同时,建立起和远端分支的关联关系,如果建立起关系,以后不必输入远程仓库名、本地分支、远程仓库分支,可以直接使用 git push 来推到远端;反过来说,在建立联系的时候,必须要有远程仓库名、本地分支、远程仓库分支。

1、添加远程仓库在本地的别名

若要多次上传,使用别名会更加方便,添加远程仓库在本地的别名本质就是在本地添加远程仓库的映射,可以在本地添加多个仓库映射。

基本格式如下:

# <nickname>: 远程仓库在本地的别名,一般是origin
# <address>:  远程仓库的url
git remote add <nickname> <address>

使用 git remote 命令查看远程仓库的映射是否存在 

2、本地仓库 — 远程仓库(git push)

接下来便可以使用 git push 将本地仓库的内容添加到远程仓库了,远程分支在省略的情况下默认和本地分支保持一致。

# 等价于 git push origin master:master
# 含义: 将本地的master分支推送到 origin 仓库的master分支
git push origin master

注意:若遇上下面的情况,是因为本地内容和远程内容不一致(可能是其他人提交的代码或者远程分支的更新),所以Git 拒绝了你的推送。

此时需要先让本地内容和远程仓库的内容同步,使用 git pull 命令将远程仓库的内容同步到本地,相当于做了 “拉取 + 合并” 两步。(合并的作用是将目标分支的修改应用到当前分支)

# 拉取origin远程仓库的master分支,同时与当前分支进行合并
git pull origin master

# 等价于下面两步
git fetch origin master    # 仅拉取
git merge origin master    # 仅合并

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1456842.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LLM应用开发与落地:chroma的近似搜索问题

背景 最近开始测试一个游戏客户的RAG模块&#xff0c;发现一个向量数据库中大家容易忽略的一个点&#xff1a;近邻搜索算法。一开始我们选择的是chroma作为向量数据库&#xff0c;因为chroma的用户接口和设计非常简单&#xff0c;而我偏向于简单。创建collection时设置的距离计…

stable-video-diffusion 图生视频模型diffusers使用案例

T4卡16g运行: 参考:https://huggingface.co/docs/diffusers/main/en/using-diffusers/text-img2vid 案例用的google colab T4显卡运行 安装包:pip install diffusers accelerate 代码 import torch from diffusers import StableVideoDiffusionPipeline from diffusers.uti…

SPSSAU【文本分析】|我的项目

文本分析之我的项目 SPSSAU提供文本分析模块&#xff0c;其单独针对文本数据进行研究和分析使用&#xff0c;其包括词云分析、文本情感分析、文本聚类分析、社会网络关系分析、LDA主题分析、新词发现和我的词库等功能。使用SPSSAU进行文本分析时&#xff0c;涉及下述内容。分别…

【刷刷刷,爽!】leetcode198. 打家劫舍

题目如上&#xff01; 这是一道非常非常标准的初级动规题。属于走楼梯的进阶版。所以我们尝试把他变成走楼梯。 怎么变&#xff1f;或者说是怎么看成走楼梯。 答案是&#xff01;&#xff01;&#xff01;&#xff01; 看最后一个数。 往往会最有灵感。 比如示例1中[1,2,3,4]&a…

docker 服务的启动命令

Docker 服务的启动命令主要涉及 Docker Daemon 的启动和管理。Docker Daemon 是在后台运行的服务进程&#xff0c;负责管理 Docker 容器的创建、运行、停止等操作。根据你使用的操作系统&#xff0c;启动 Docker 服务的命令可能有所不同。 对于 Linux 系统 使用 systemctl (适…

【二十四】【C++】多态

多态的基本概念 多态是一种允许使用相同的接口来访问不同的底层形式&#xff08;类型&#xff09;的对象的能力。C中的多态主要通过以下两种方式实现&#xff1a; 编译时多态&#xff08;静态多态&#xff09;&#xff1a;通过函数重载和运算符重载实现。 运行时多态&#x…

基于数字双输入的超宽带Doherty功率放大器设计-从理论到ADS版图

基于数字双输入的超宽带Doherty功率放大器设计-从理论到ADS版图 参考论文: 高效连续型射频功率放大器研究 假期就要倒计时啦&#xff0c;估计是寒假假期的最后一个博客&#xff0c;希望各位龙年工作顺利&#xff0c;学业有成。 全部工程下载&#xff1a;基于数字双输入的超宽…

机器人初识 —— 定制AI

一、机器人设计难点 波士顿动力设计的机器人&#xff0c;尤其是其人形机器人Atlas和四足机器人Spot等产品&#xff0c;在技术上面临多重难点&#xff1a; 1. **动态平衡与稳定性**&#xff1a;双足或四足机器人在运动时需要维持极高的动态平衡&#xff0c;特别是在不平坦地面…

KMP算法简介以及相关例题的分析

一.KMP算法简介 KMP 算法是 D.E.Knuth、J,H,Morris 和 V.R.Pratt 三位神人共同提出的&#xff0c;称之为 Knuth-Morria-Pratt 算法&#xff0c;简称 KMP 算法。该算法相对于 Brute-Force&#xff08;暴力&#xff09;算法有比较大的改进&#xff0c;主要是消除了主串指针的回溯…

【Java面试】MongoDB

目录 1、mongodb是什么&#xff1f;2、mongodb特点什么是NoSQL数据库&#xff1f;NoSQL和RDBMS有什么区别&#xff1f;在哪些情况下使用和不使用NoSQL数据库&#xff1f;NoSQL数据库有哪些类型?启用备份故障恢复需要多久什么是master或primary什么是secondary或slave系列文章版…

【Vuforia+Unity】01实现单张多张图片识别产生对应数字内容

1.官网注册 Home | Engine Developer Portal 2.下载插件SDK&#xff0c;导入Unity 3.官网创建数据库上传图片&#xff0c;官网处理成数据 下载好导入Unity&#xff01; 下载好导入Unity&#xff01; 下载好导入Unity&#xff01; 下载好导入Unity&#xff01; 4.在Unity设…

unity C#中的封装、继承和多态简单易懂的经典实例

文章目录 封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism) C#中的封装、继承和多态是面向对象编程&#xff08;OOP&#xff09;的三大核心特性。下面分别对这三个概念进行深入解释&#xff0c;并通过实例来说明它们在实际开发中的应用。 封装 (Encapsulation) 实例…

11. Springboot集成Dubbo3(二)示例demo

目录 1、前言 2、注册中心 3、快速开始 3.1、添加dubbo3依赖 3.2、dubbo3-api ​编辑 3.3、dubbo3-server 3.3.1、添加依赖 3.3.2、实现IUserService 3.3.3、添加配置文件application.properties 3.3.4、修改Application启动类 3.3.5、出错解决 3.4、dubbo3-porta…

世界顶级名校计算机专业,都在用哪些书当教材?

前言 在当今信息化、数字化时代&#xff0c;计算机科学已成为全球最为热门和重要的学科之一。世界顶级名校的计算机专业&#xff0c;更是培养未来行业领袖和创新人才的重要基地。那么&#xff0c;这些名校的计算机专业究竟使用哪些教材呢&#xff1f;这些教材又具有哪些特色和…

智能化机械生产引擎:亿发制造ERP系统助帮助工厂真正把控车间管理

工厂的制造管理过程以车间管理为核心&#xff0c;而车间管理涉及到生产的下达、派工、汇报等复杂流程&#xff0c;几乎包含了生产的全过程。这种繁琐性使得车间管理变得异常困难&#xff0c;因此&#xff0c;引入一款专业的制造ERP软件成为解决难题的有效途径。 在制造业引入E…

文件IO及目录IO——day05

文件IO还剩下一个知识点&#xff0c;今天主要内容是目录IO 文件IO lseek lseekoff_t lseek(int fd, off_t offset, int whence); 功能:重新设定文件描述符的偏移量 参数:fd:文件描述符offset:偏移量whence:SEEK_SET 文件开头SEEK_CUR 文件当前位置SEEK_END 文件末尾…

【PyQt6] 框选截图功能

1 简介 书接上回, 全屏截图实现起来很简单, 来点稍微复杂点的, 框选截图 原理很简单, 弄个控件实现全屏半透视, 在全屏控件上画一个选框或者再弄一个几乎全透的子控件,实现鼠标拖动,缩放,移动, 键盘wasd 微调 用一个控件实现起来会很完美, 但是逻辑全部堆砌在一起,看代码会很…

PWM功能介绍 和配置

泰山派默认提供了3组PWM的GPIO &#xff0c; 为了检测PWM的输出&#xff0c;我们可以配合逻辑分析仪来查看效果&#xff0c;或者搭配STC8的LED灯 PWM 测试 列举所有的PWM设备&#xff1a; # 查找所有有pwm名称的文件 find / -name "pwm" # pwm4: pwmfe6e0000 edp屏幕…

VPX信号处理卡设计原理图:9-基于DSP TMS320C6678+FPGA XC7V690T的6U VPX信号处理卡 信号处理 无线电通信

一、概述 本板卡基于标准6U VPX 架构&#xff0c;为通用高性能信号处理平台&#xff0c;系我公司自主研发。板卡采用一片TI DSP TMS320C6678和一片Xilinx公司Virtex 7系列的FPGA XC7V690T-2FFG1761I作为主处理器&#xff0c;Xilinx 的Aritex XC7A200T作为辅助处理器。XC7A2…

OpenAI视频生成模型Sora的全面解析:从ViViT、扩散Transformer到NaViT、VideoPoet

前言 真没想到&#xff0c;距离视频生成上一轮的集中爆发(详见《视频生成发展史&#xff1a;从Gen2、Emu Video到PixelDance、SVD、Pika 1.0、W.A.L.T》)才过去三个月&#xff0c;没想OpenAI一出手&#xff0c;该领域又直接变天了 自打2.16日OpenAI发布sora以来(其开发团队包…