Git学习笔记(两)

删除文件

     假设需要从Git删除文件,我们必须从删除列表中的跟踪文件(从临时区域中删除)。然后提交。可以使用git rm工作订单完成。联合司令部从工作区删除指定的文件。以后就不会出如今未跟踪文件清单中。最后提交时,该文件不再纳入版本号管理中。

假设文件删除之前被改动过且已经放到了暂存区域中,则必须使用强制删除选项-f。以防误删文件后丢失改动的内容。另外,假设想把文件从Git仓库中删除(即从暂存区域中删除),但仍希望保留在工作区域中的文件,即仅从跟踪清单中删除时,使用—cached选项。

Git的文件的模式匹配方式

结合样例理解。$git rm log/\*.log。须要注意的是*前面的反斜杠\。Git拥有自己的文件模式扩展匹配方式,所以能够不使用shell帮忙展开匹配。不加这一反斜杠的模式是shell的文件匹配模式,加这一反斜杠的模式是Git自身的文件匹配模式。

差别在于,使用shell的文件匹配模式,只删除指定文件夹下的文件而不会递归匹配删除。假设使用Git的文件匹配模式。则会删除该文件夹及其子文件夹下匹配的文件。Git命令$git rm \*~删除当前文件夹及其子文件夹下全部以~结尾的文件。

命令git log –pretty=format:“”介绍

     该命令用于格式化log输出的结果,这种输出可以便于后期编程时log的提取分析。格式样例: $git log –pretty=format:“%h- %an, %ar : %s”。以下是格式占位符写法及其代表意义:

%H       提交对象(commit)的完整哈希字符串

%h       提交对象的简短哈希字符串

%T       树对象(tree)的完整哈希字符串

%t        树对象的简短哈希字串

%P        父对象(parent)的完整哈希字串

%p       父对象的简短哈希字串

%an      作者(author)的名字

%ae      作者的电子邮件地址

%ad      作者修订日期(能够用—date=选项定制格式)

%ar      作者修订日期,按多久曾经的方式显示

%cn      提交者(committer)的名字

%ce      提交者的电子邮件地址

%cd      提交日期

%cr      提交日期,按多久曾经的方式显示

%s       提交说明

git remote命令

  git remote命令用于查看当前配置中有哪些远程仓库(注意仓库和分支的差别)。在克隆完某个项目后,至少可以看到一个名为origin的远程库。Git默认使用origin来标识所克隆的原始仓库。加上參数-v或—verbose,可以显示相应的克隆地址。

Git加入新的远程仓库

   使用命令git remote add [shortname] [url]。

当中。shortname是远程仓库的名字,用于标识该远程仓库。比如,$git remoteadd pb git://github.com/paulboone/ticgit.git。

从远程仓库抓取数据

   使用命令$git fetch [remote-name]。该命令会从远程仓库中拉取全部你本地仓库中没有的数据。须要注意的是。fetch命令只不过将远程的数据拉到本地仓库,并不自己主动合并到当前工作分支

假设设置了某个分支用于跟踪远程库的某个分支,则能够使用$git pull命令自己主动抓取数据,并将远程仓库的分支合并到本地仓库中的当前分支。其实,git clone命令本质上是自己主动创建了本地的master分支用于跟踪远程仓库中的master分支。

推送数据到远程仓库

   命令: git push [remote-name][branch-name],将本地branch-name分支(即仓库)上的数据推送到远程remote-name仓库中。比如,$git push origin master命令将本地master分支推送到远程originserver上。须要注意的是,仅仅有在所克隆的server上有写权限。或同一时刻没有其它人在推送数据,该命令才干运行成功。假设在推送数居前。已经有其它人推送了若干更新。则你的推送操作会被驳回。你必须把他们的更新抓取到本地。进行合并后才干再次推送。

查看远程仓库信息

使用命令: $git remote show [remote-name]。比如查看所克隆的origin仓库,$git remoteshow origin。

远程仓库的删除和重命令

命令git remote rename改动某个远程仓库在本地的简短命名。比如,$git remote rename pb paul将远程仓库在本地的简短命名pb改为paul。删除远程仓库命令git remote rm。比如,$git remote rm paul,删除远程仓库paul。

标签

Git同意对某一时间点上的版本号打上标签,用以标识该时间点上的版本号。人们在公布某个软件版本号时,便是用打标签来进行不同软件版本号的识别。

列出标签

git tag列出现有的标签;git tag –l “v1.4.2.*”用特定的搜索模式列出符合条件的标签(使用模式匹配)。

含附注的标签(annotated tag)

annotated tag是存储在仓库中的一个独立对象,有其自身的校验和信息。包括着标签的名字、电子邮件地址、日期,以及标签说明,该标签本身也同意使用GNU Privacy Guard (GPG)来签署或验证。创建annotated tag的命令: git tag –a <annotated tag name> -m <description>。

显示标签的命令: git show <tagName>。假设拥有自己的私钥,则还可用GPG来签署标签。语法为: git tag –s<tagName> -m <description>。签署标签后,再执行git show便会看到相应的GPG签名的输出信息。

轻量级标签

轻量级标签是一个保存这相应提交对象的校验和信息的文件。创建lightweight标签的语法: git tag <tag name>。

查看轻量标签信息的命令: git show <lightweight tag name>。

验证标签

命令语法: git tag –v <tag-name>,用该命令验证已经签署的标签。该命令会调用GPG来验证签名,所以须要有签署者的公钥存放在keystring中,才干验证。

比如,$git tag –v v1.4.2.1。

后期加注标签

能够在后期对早先的某次提交加注标签。仅仅要在打标签的时候跟上相应提交对象的校验和(或前几位字符)就可以。比如,$git tag –a a1.2.9 42ce46。

分享标签

默认情况下。git push并不会把标签传送到远程server上,仅仅有通过显示命令才干分享标签到远程仓库。命令格式为: git push origin <tagname>。比如,$git push origin v1.5。

假设须要一次把全部本地新增的标签推送到远程仓库,则使用命令$git push origin –tags。
Git命令别名

用git config命令为命令设置别名。比如:

    $git config --global alias.co checkout

    $git config --global alias.br branch

使用这样的技术还能创造出新的命令。比如取消暂存文件输入的命令比較繁琐,则能够设置: $git config –global alias.unstage ‘reset HEAD -’。此时,$git unstage file和$git reset HEAD file当量。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

posted on 2015-08-06 13:06  gcczhongduan  阅读(96)  评论(0编辑  收藏  举报