【Git从入门到精通】Git基础
创始人
2025-05-29 22:00:31
0

通过学习这一部分内容,你就可以开始使用Git了

获取Git仓库

两种方式

  1. 将现有项目加入Git中
  2. 从服务器上克隆现有的Git仓库

初始化Git仓库

要想让现有项目加入Git,只需要进入项目目录并输入:

git init

在这里插入图片描述

这个命令会在此目录下创建一个.git的目录,这个目录包含了构成Git仓库骨架的所有必须的文件。

如果后面你不想此项目继续使用Git的话,你可以试试rm -rf .git

克隆现有仓库

如果需要获取现有仓库的一份副本,可以使用git clone命令.Git会对服务器仓库的几乎所有数据进行完整复制,而不是只复制当前工作目录。git clone默认会把服务器上整个项目历史中每个文件的所有历史版本都拉取下来。如果你的服务器磁盘损坏了,也可以通过客户端的仓库进行恢复。

克隆仓库需要使用git clone [url]命令。

git clone https://github.com/tanruike/gitstudy

这会创建一个gitstudy的新目录,并在其中初始化.git目录,然后将远程仓库中的所有数据拉取到本地并检出最新版本的可用副本。

如果你想讲项目克隆到其他名字的目录中,可以目录名作为命令行选项传入:

git clone https://github.com/tanruike/gitstudy mygitstudy

Git除了使用以上的http协议,还可以使用git和ssh协议。

在仓库中记录变更

现在已经有一个Git仓库了,下一步就是做出一些更改,当项目到达某个需要记录的状态时间向仓库提交这些变更的快照。

工具目录中的每个文件都会处于两种状态之一:未跟踪(untracked)和已跟踪(untracked)。

已跟踪说的是指上一次快照中包含的文件,这部分文件又可以分为未修改、已修改、已暂存三种状态。未跟踪的就是除了已跟踪之外的文件。当你完成仓库克隆时,所有的文件都处于已跟踪未修改的状态。

如果修改了文件,那么它的状态就会变成已修改,此时你可以将这些文件加入暂存区,提交所有的已暂存的文件。然后重复这个过程。

大致情况如下图所示

在这里插入图片描述

查看当前文件状态

查看当前文件的状态所使用的是git status命令

比如:

在这里插入图片描述

上述说明你的仓库中有两个文件处于未追踪的状态,因为这两个文件是新创建的。在上一次快照中并没有这两个文件。Git不会主动将这些文件包含到下一次提交的文件范围中,这让可以避免不小心将不想追踪的文件包含进来。

当然你也可以添加.gitignore文件来提醒Git你不想添加那些文件或者目录。

跟踪新文件

使用git add命令让Git开始跟踪新的文件。执行一下命令来跟踪未跟踪的文件。

git add 2.md

执行后可以查看文件的状态

在这里插入图片描述

可以看到 2.md 在暂存区等待被提交

也可以使用git add .来添加所有未追踪的文件

在这里插入图片描述

暂存已修改的文件

现在我修改一下2.md文件,2.md之前已经被追踪过了。使用git status来查看文件的状态

在这里插入图片描述

2.md出现在了已修改但未暂存的区域中,这说明处于被追踪的文件应该被修改了,但是还没有被添加到暂存区。想要暂存这些文件,需要执行git add命令。这个命令既可以用来追踪新文件,也可以用来暂存文件,还可以把存在合并冲突的文件标记为已解决。

我们可以把git add命令看成 添加内容到下一次提交中 。此时我们执行git add在次查看文件的状态。

在这里插入图片描述

注意上面第一章图中,2.md同时出现在了暂存去和已修改未暂存区,这是因为在暂存后文件又发生了更改,而暂存去保存的是下次要提交的内容。

显示更简洁的信息

git status -s 或者 git status --short

在这里插入图片描述

已暂存的文件会有A标记,已修改的文件会有M标记。左列表明了文件是否已暂存,右侧则是是否修改。未被追踪的文件则会出现??标记。

忽略文件

如果你不希望某个文件或者某个文件夹被Git添加,甚至不想让其出现在未被追踪的列表下面。比如说.idea、日志文件等。在这种情况下,可以创建名为.gitignore文件,在这个文件中列出你不想添加的文件。

例如输入以下命令:

cat .gitignore
*.idea

这个文件告诉Git忽略所有以.idea结尾的文件。

文件的匹配规则如下所示:

  • 以#开头的行会被忽略。相当于注释
  • 支持标准的glob模式(简化版的正则表达式)
  • 以 / 开头的模式用于禁止递归匹配
  • 以 / 结尾的表示目录
  • !开始的表示取反

讲一些常用的正则表达式:

  • *匹配0个或更多字符
  • [abc]匹配括号内的任一字符
  • ?匹配任一单个字符
  • [0-9]范围匹配
  • 。。。

更多的可以查看GitHub所维护的.gitignore文件

查看已暂存和未暂存的变更

看到这里你可能会说前面的git status不就是查看变更吗?那么你可以继续往下看。

git diff这个命令不同于git status,它可以告诉你修改的具体内容,而不仅仅是修改了那些文件,git diff输出的是补丁。

比如我执行git status命令
在这里插入图片描述

可以看到有一个修改为暂存的文件。那么输入git diff呢?
在这里插入图片描述

其中的+号就是新添加的内容。

这条命令会将工作目录中的内容和暂存去的文件做一个对比,对比的结果就是显示的内容。

这里需要注意的是这个文件必须是对追踪过的文件,并且是与暂存区的文件做对比,如果你将所有的变更都添加进了暂存区,那么这个命令不会有任何输出。

提交变更

当你的暂存区已经准备好了,你想让这些文件进入Git仓库,那么你可以使用git commit命令来提交这些内容,需要注意的是未加入暂存区的内容并不会被提交。

git commit

当你输入这个命令之后,会自动打开一个文本编辑器,用于提示你输入这次提交的提交信息。

在这里插入图片描述

你可以在上面输入你这次提交的主要变更内容,以便于给其他开发者一个提示。

在这里插入图片描述

然后按esc 然后输入 :wq保存退出

在这里插入图片描述

这将清空你的暂存区。

当然上述的步骤有点复杂,你可以可以在提交的时候直接在命令行键入提示信息。只需要在后面加上 -m 选项。

git commit -m 'git 基础'

在这里插入图片描述

提交之后你可以看到此次提交的一些相关的信息,包括分支,校验和,改动了多少文件及行数。

跳过暂存区

如果你不想将文件添加到暂存区,在提交的话,你可以跳过暂存区直接进行提交。你可以加上 -a 选项:

git commit -a -m 'new commit'

移除文件

如果你有以下需求,将某个文件从Git中移除,如果你只是简单的删除文件,那么执行git status是就会发现文件出现在了change not staged for commit区域

在这里插入图片描述

这是你执行git rm,Git才会把文件的移除状态记录到暂存区。

在这里插入图片描述

这样你下次提交的时候,这个文件就不存在了,也不会被Git追踪了。

当然这样子你的文件也会被删除,如果不只是不想文件被追踪,当时想保留在工作目录,只需要加上 --cached选项即可。

git rm --cached README.MD

当然也可以穿正则表达式进行匹配

移动文件

如果你在目录中重命名了文件,Git仓库的元数据并不会记录这次操作。所以可以使用以下命令进行重命名。

git mv file_from file_to

实际上这个命令执行了以下三个命令

mv file_from file_to

git rm file_from

git add file_to

查看提交历史

使用git log可以查看所有的提交历史。最新的提交会显示在最前面。

在这里插入图片描述

如果你加上-p参数,他会显示每次提交的差异,还可以加上 -2 只显示两次提交。

在这里插入图片描述

当然还有其他选项可供选择,这里不一一赘述。有需要可自行查阅。

撤销操作

如果你在提交之后,发现某个文件没有提交上,或者写错了提交信息,如果你想重新尝试提交,可以试试 --amend 选项

git commit --amend

这个命令会提交暂存区的内容。如果你未做任何改动,那么提交快照不会有改变,但你可以改变提交信息。

比如过,你提交后发现忘记添加某个文件,你可以:

git commit -m 'initial commit'

git add forgotten_file

git commit --amend

最终只产生了一次提交,因为第二个提交命令修正了第一个提交的结果。

撤销已暂存/已修改的文件

看下面这张图片

在这里插入图片描述

通过提示可以看出你可以使用

git restore --staged file_name将文件移除暂存区

在这里插入图片描述

当然可以撤销对文件的修改。可以使用git restore 但需要注意的是,如果你一但执行,那么这些修改则再也找不回来。如果你只是暂时的想要隐藏这些修改可以使用git stash命令。

通过这一节的学习,你已经基本可以独立的使用git了,关于远程仓库的使用和分支在后面我会逐步介绍。

相关内容

热门资讯

银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...
君赛生物港股IPO,增聘兴证国... 跟丰宜科技一样,正冲刺港股IPO的上海君赛生物股份有限公司(简称“君赛生物”)增聘一位整体协调人。 ...
圣邦股份明日上市:暗盘涨24%... 雷递网 雷建平 6月25日 圣邦微电子(北京)股份有限公司(简称:“圣邦股份”,股票代码:“0366...
科技“吃肉”,券商跟着“喝汤”... 当科技持续成为市场核心主线,押中硬科技项目的券商也成为被追逐的焦点。 6月24日,半导体零部件概念股...