Git的文件命令

简介: Git的文件命令

 文件状态

untracked未跟踪

未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged

tracked已跟踪被纳入版本控制

Unmodified

文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改, 而变为Modified,如果使用git rm移出版本库, 则成为Untracked文件。

Modified

文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过git add可进入暂存staged状态, 使用git checkout 则丢弃修改过,返回unmodify状态, 这个git checkout即从库中取出文件, 覆盖当前修改。

Staged

暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为Unmodify状态. 执行git reset HEAD filename取消暂存,文件状态为Modified。

查看文件状态

git status -s

image.gif

暂存区

文件加入暂存区

add后面加的是文件的类型,*代表所有文件

git add *

image.gif

文件取消暂存区

reset后面加的是文件的类型,*代表所有文件

git reset *

image.gif

提交与删除

提交暂存区文件到版本库

git commit -m "提交信息概述,如版本1"

image.gif

-m : 如果不加m参数,会进入类似vim编辑

查看提交信息

git log --oneline

image.gif

修改提交记录最新一次的提交信息

git commit --amend  -m "提交信息概述"

image.gif

删除文件

git rm 文件名

image.gif

只是删除工作目录的文件,我们的版本库里面还是存在的。删除文件会把这个文件直接放入暂存区

挽救已被删除的文件或目录

git checkout index.html

image.gif

当使用git checkout命令时,Git 会切换到指定的分支,但如果后面接的是文件名或路径,Git则不会切换分支,而是把文件从.git目录中复制一份到当前的工作目录。更精准地说,这个命令会把暂存区中的内容或文件拿来覆盖工作目录中

挽救所有删除文件

git checkout .

image.gif

这个技巧不仅可以将删除的文件挽救回来,当改动某个文件后反悔了,也可以用它把文件恢复到上一次Commit的状态。不是所有情况下都能恢复被删除的文件的。因为整个Git的记录都是放在根目录下的 .git目录中,如果这个目录被删除了,也就意味着历史记录也被删除了,那么删除的文件也就不能恢复了

忽略列

一般我们总会有些文件无需纳入Git的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。在这种情况下,我们可以在工作目录中创建一个名为 .gitignore的文件(文件名称固定),列出要忽略的文件模式

创建.gitignore文件

touch .gitignore

image.gif

编写.gitignore文件的忽略规则

vim .gitignore

image.gif

忽略规则

#以斜杠“/”开头表示目录

#以星号“*”通配多个字符

#以问号“?”通配单个字符

#以方括号“[]”包含单个字符的匹配列表

#以叹号“!”表示不忽略(跟踪)匹配到的文件或目录

/public/*    # 忽略public下的所有目录及文件

!/public/assets  #不忽略/public/assets,就是特例的意思,assets文件不忽略

index.class          # 忽略具体的文件

*.class        # 忽略所有的class

[ab].class        # 忽略 a.class b.class

日志和历史命令

查看记录

git log

image.gif

git log --oneline

image.gif

--graph : 查看分支合并图

--oneline : 标记把每一个提交压缩到了一行中

获取执行过的命令

git reflog

image.gif

比较文件差异

比较工作区和暂存区差异

git diff

image.gif

比较暂存区差异

git diff --cached

image.gif

---:标记原始文件

+++:标记新文件

@@:两个不同文件版本的上下文行号。

-: 原始文件删除改行

+:原始文件增加一行


相关文章
|
27天前
|
开发工具 git
git 常用命令
这些只是 Git 命令的一部分,Git 还有许多其他命令和选项,可根据具体需求进行深入学习和使用。熟练掌握这些命令能够帮助你更高效地管理代码版本和协作开发。
|
19天前
|
机器学习/深度学习 Shell 网络安全
【Git】Git 命令参考手册
Git 命令参考手册的扩展部分,包含了从基础操作到高级功能的全面讲解。
27 3
|
1月前
|
缓存 Java Shell
[Git]入门及其常用命令
本文介绍了 Git 的基本概念和常用命令,包括配置、分支管理、日志查看、版本回退等。特别讲解了如何部分拉取代码、暂存代码、删除日志等特殊需求的操作。通过实例和图解,帮助读者更好地理解和使用 Git。文章强调了 Git 的细节和注意事项,适合初学者和有一定基础的开发者参考。
52 1
[Git]入门及其常用命令
|
2月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
142 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
2月前
|
Shell 开发工具 git
git学习三:git使用:删除仓库,删除仓库内文件
通过GitHub的设置页面删除仓库,以及如何使用Git命令行删除仓库中的文件或文件夹。
184 1
git学习三:git使用:删除仓库,删除仓库内文件
|
2月前
|
开发工具 git 索引
git上面中新建gitignore文件,并且去除已经在仓库版本管理中的文件夹
git上面中新建gitignore文件,并且去除已经在仓库版本管理中的文件夹
97 4
|
1月前
|
开发工具 git 开发者
|
1月前
|
开发工具 git 开发者
提升Git效率:掌握这5个高级命令
【10月更文挑战第17天】
62 0
|
2月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
42 1
|
3月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
无论团队项目还是个人开发,掌握 Git 命令都是必备技能。本文介绍 Git 的基本概念与命令,如初始化仓库 (`git init`)、添加文件 (`git add`)、提交更改 (`git commit`)、检出分支 (`git checkout`)、合并分支 (`git merge`) 等,还分享了高级技巧如查看差异 (`git diff`)、撤销提交 (`git revert`)、修复合并冲突 (`git mergetool`) 和使用别名简化命令 (`git config --global alias.ci commit`)。