(八) Git基本操作
最后更新于:2022-04-01 19:53:44
#### 删除文件
直接在工作区删除,对暂存区和版本库没有任何影响。本地删除如果要反映在暂存区中应该用git rm命令,对不想删除的文件执行git checkout -- ,可以让文件在工作区重现。用git rm命令执行删除后,删除动作加入了暂存区,这时执行提交动作就从真正意义上执行了文件删除,不过文件只是在版本库的最新提交中被删除了,在历史提交中尚在。
$ git add -u 将本地有改动(包括修改和删除)的文件标记到暂存区。
#### 恢复删除的文件
~~~
$ git cat-file -p HEAD^:test.txt > test.txt 从前一提交中恢复test.txt文件
$ git show HEAD^:test.txt > test.txt 效果相同
$ git checkout HEAD^ -- test.txt 也可以
$ git add -A 将工作区的所有改动及新增文件添加到暂存区
~~~
然后执行commit操作,则文件被恢复
#### 移动文件(改名操作)
改名操作相当于对旧文件执行删除,对新文件执行添加,git mv可以由git rm和git add两条命令取代
$ git mv oldname newname 完成改名操作
#### 查看版本号
$ git describe 查看当前版本号
git log命令的--decorate参数可以在提交ID的旁边显示该提交关联的引用(里程碑或分支)
#### 选择性添加文件
$ git add -i可以进入一个交互式界面操作
文件忽略功能
若把编译的目标文件及其他临时文件加入版本库中,浪费存储空间不说,甚至还会造成冲突。
可以创建一个.gitignore文件,其作用范围是所处目录及其子目录,编辑好要忽略的文件,然后添加到版本库中。如果不希望添加到库里,也不希望.gitignore文件带来干扰,可以在忽略文件中忽略自己。
被忽略以后,只有使用git status命令的--ignore参数,才会在状态显示中看到被忽略的文件。添加时git add -A和git add .都失效,只有在添加操作的命令行中明确写入文件名并提供-f参数才能真正添加。忽略只对未跟踪文件有效,对于已加入版本库的文件无效。
文件.gitignore设置的文件忽略是共享式的。之所以被称为“共享式”,是因为.gitignore被添加到版本库后成为了版本库的一部分,当版本库共享给他人(克隆),或者把版本库推送(PUSH)到集中式的服务器或他人的版本库时,这个忽略文件就会在他人的工作区中同样生效。相对应的是独享式,有两种方式:
第一种是针对具体版本库的,即在版本库.git目录下的一个文件.git/info/exclude来设置文件忽略;
另一种是全局的,即通过Git的配置变量core.excludesfile指定的一个忽略文件,其设置的忽略对所有本地版本库均有效。
如果文件忽略对于所有使用此版本库工作的人都有益,就通过在版本库相应目录下建一个.gitignore文件建立忽略;否则,如果是需要忽略工作区中创建的一个试验目录或试验性的文件,则使用本地忽略。
**忽略语法:**
忽略文件中的空行或以#开始的行会被忽略
可以使用通配符,参见Linux手册:glob(7)
如果名称的最前面是一个路径分割符(/),表明要忽略的文件在此目录下,而非子目录的文件
如果名称的最后面是一个路径分割符(/),表明要忽略的是整个目录,同名文件不忽略,否则同名的文件和目录都忽略
通过在名称的最前面添加一个感叹号(!),代表不忽略
#### 文件归档
git archive命令,可以对任意提交对应的目录树建立归档。
~~~
$ git archive -o latest.zip HEAD 基于最新提交建立归档文件latest.zip
$ git archive -o partial.tar HEAD src doc 只把目录src和doc建立到归档partial.tar中
$ git archive --format=tar --prefix=1.0/ v1.0 | gzip > foo-1.0.tar.gz 基于里程碑v1.0建立归档,并且为归档中的文件添加目录前缀1.0
~~~
在建立归档时,如果使用树对象ID进行归档,则使用当前时间作为归档中文件的修改时间,而如果使用提交ID或里程碑等,则使用提交建立的时间作为归档中文件的修改时间。
如果使用tar格式建立归档,并且使用提交ID或里程碑ID,还会把提交ID记录在归档文件的文件头中。记录在文件头中的提交ID可以通过git tar-commit-id命令获取。
如果希望在建立归档时忽略某些文件或目录,可以通过为相应文件或目录建立export-ignore属性加以实现。
';