`
sunxboy
  • 浏览: 2829762 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

10 个很有用的高级 Git 命令

 
阅读更多

迄今,我已经使用Git很长一段时间了,考虑分享一些不管你是团队开发还是个人项目,都受用的高级git命令。

1. 输出最后一次提交的改变

这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。

git archive -o ../updated.zip HEAD $(git diff --name-only HEAD^)
 

 

2. 输出两个提交间的改变

类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。

 

git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff --name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE) 

 

 

3. 克隆 指定的远程分支

如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。

git init
git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
git checkout BRANCH_NAME_HERE

 

4. 应用 从不相关的本地仓库来的补丁

如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。

git --git-dir=PATH_TO_OTHER_REPOSITORY_HERE/.git format-patch -k -1 --stdout COMMIT_HASH_ID_HERE| git am -3 -k

 

5. 检测 你的分支的改变是否为其它分支的一部分

cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:

git cherry -v OTHER_BRANCH_NAME_HERE
#例如: 检测master分支
git cherry -v master

 

6.开始一个无历史的新分支

有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。

git checkout --orphan NEW_BRANCH_NAME_HERE

 

7. 无切换分支的从其它分支Checkout文件

不想切换分支,但是又想从其它分支中获得你需要的文件:

git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE 

 

8.忽略已追踪文件的变动

如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有可能会经常用到fetch和merge。但是有时候这样会重置您的环境配置文件,如此的话,您就得在每次merge后修改它。使用这一命令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。

git update-index --assume-unchanged PATH_TO_FILE_HERE

 

9.检查提交的变动是否是release的一部分

name-rev命令能告诉您一个commit相对于最近一次release的位置。使用这条命令,您就可以检查您所做出的改动是否是release的一部分了。

git name-rev --name-only COMMIT_HASH_HERE

 

10.使用rebase推送而非merge

如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。

git pull --rebase

 您也可以将某条branch配置为总是使用rebase推送:

git config branch.BRANCH_NAME_HERE.rebase true

 

分享到:
评论

相关推荐

    Git-2.28.0-64-bit.rar

    Git 是一个快速、可扩展的分布式修订控制系统,具有异常丰富的命令集,可提供高级操作和对内部功能的完全访问。 有关有用的最小命令集,请参阅 gittutorial[7]以开始,然后查看 giteveryal[7]。Git 用户手册有更...

    Git Community Book 中文版

    如果前面的这些东东你都掌握了,我们就会讲Git的高级用法 的高级用法,这些高级用法也许大多数人很少使用,但是在特定 的环境会非常有用。学习这些用法(命令),你将能获得全面的日常Git知识; 你将能成为Git大师。 ...

    progit(git中文文档)

    *第七章*关于 Git 的高级命令。你将学习到一些高级主题,诸如掌握可怕的“reset”命令,使用二分搜索识别错 误,编辑 历史,细节版本选择等等。本章的介绍将丰富你的 Git 知识,让你成为一个真正的大师。 *第八章*关于 ...

    git:Git中部分克隆的补丁(允许省略提交,树和斑点)。 请参阅自述文件

    Git-快速,可扩展的分布式修订控制系统Git是一个快速,可扩展的分布式修订版本控制系统,具有异常丰富的命令集,该命令集提供高级操作和对内部组件的完全访问权限。 Git是一个受GNU通用公共许可证版本2涵盖的开放源...

    meta-git:使元仓库工作更轻松的工具

    meta-git的真正功能在于它抽象了高级git的用法和配置,使任何开发人员都能轻松上手。 什么是元存储库? “元存储库是允许在特定配置下跟踪各种存储库的存储库” 当您需要将回购使用特定版本以使项目正常运行时...

    git:Git源代码镜像-这是仅发布的存储库,所有拉取请求都将被忽略。 请按照DocumentationSubmittingPatches程序进行任何改进

    Git是一个快速,可扩展的分布式修订版本控制系统,具有异常丰富的命令集,该命令集提供高级操作和对内部组件的完全访问权限。 Git是GNU通用公共许可证版本2涵盖的开放源代码项目(其中某些部分使用了不同的许可证,...

    git_cheatsheet:基于Coursera上的Git和GitHub入门课程的Git速查表

    高级Git备忘单 git commit -a :自动git commit -a文件git log -p :产生补丁文本git show :显示各种对象git diff :与Linux diff命令相似,并且可以显示各种提交中的差异git diff --staged :别名--cached ,这将...

    吉特

    Git是一个快速,可扩展的分布式修订版本控制系统,具有异常丰富的命令集,该命令集提供高级操作和对内部组件的完全访问权限。 Git是一个受GNU通用公共许可证版本2涵盖的开放源代码项目(其中某些部分具有不同的许可...

    theme-bobthefish:以Powerline风格,具有Git意识的鱼为主题,经过优化,性能超凡

    b鱼 bobthefish是Powerline风格的,具有Git意识的主题,经过优化,非常棒。 安装 确保已安装“哦,我的鱼”。... 上一个命令失败( ! ) 私人模式( :locked: 或⦸ ) 您目前拥有超级大国( $ ) 后台作业

    advanced-react-patterns-v2:通过Kent Dodds高级React研讨会进行工作

    要验证设置是否正确,可以运行以下命令: git --versionnode --versionnpm --version如果您对上述任何一个都有疑问,请在此处了解有关PATH环境变量以及如何在Windows或mac / linux下修复它的更多信息。 设置您也许...

    StoX:StoX GUI

    有用的git命令commit-Visual Studio代码源控件Ctrl + Enter运行add(阶段),并将actul提交到当前分支中推/拉或同步-Visual Studio代码源控件从远程更新工作目录,反之亦然-切换分支git merge从分支合并到当前分支 ...

    实验室高级查询蒙古

    我们已经学习了一些超级有用的查询运算符,它们将帮助我们进行更好的查询以检索所需的数据。 在本实验中,我们将使用Crunchbase数据库。 请继续阅读并进行以下迭代。 要求 分叉此回购 克隆此仓库 提交 完成后,运行...

    FWRI_R_Club:非正式 FWRI R 俱乐部用户组的代码和其他资源的集合

    PowerPoint 演示文稿和以前 R 俱乐部会议的 Word 文档该小组分享的其他有用链接包括: R 包在线书籍 TBEP R 培训 R 数据科学书籍 R Markdown 在线书 高级 R 在线书籍 R 图形食谱在线 R 和 knitr 在线动态文档 初学者...

    实验室JavaScript最伟大的电影

    :flexed_biceps:要求分叉此回购克隆此仓库练习JavaScript高级方法( map , reduce , filter和sort来操作数组)提交完成后,运行以下命令: git add .git commit -m "done"git push origin master创建请求请求,...

    rrobot:R软件包,用于编写Tecan EvoWare工作列表并从Tecan iControl XML读取数据

    确保知道命令的用途(它们通常对应于您可以在EvoWare文档中找到的单个“基本”或“高级工作列表”命令。)安装要直接从git安装软件包,您需要执行以下操作: 在Mac OS上Xcode(用于构建软件包;从App Store(免费)...

    advanced-react-patterns-v2

    这是一个研讨会回购,教您如何使用React Component Patterns使您的React组件更有用和可重用,而又不牺牲简单性。 跟着前端大师一起? 前往开始! 系统要求 git v2.14.1或更高版本 的NodeJS v8.9.4或更高 npm v...

    Django-eCommerce-website:具有许多高级自定义功能的 Django 电子商务网站、RDS Postgres 并将其部署在 Amazon AWS 上

    使用 RDS Postgres 并部署在 Amazon AWS 上的 Django 电子商务网站 使用 Python 和 Django 框架的真实世界电子商务应用程序 一个全栈、功能齐全的电子商务应用...(如果在git中工作,命令如下) source env/Scripts

    Vulkan样本:适用于所有Vulkan样本的一站式解决方案

    创建一个可用作参考资料的框架,以及用作Vulkan的高级实验的沙箱 样品 一般信息 项目基础 Vulkan要点 杂项 建立 使用以下命令使用子模块克隆存储库: git clone --recurse-submodules ...

    latlong-retrieval

    高级目标 了解如何使用 确保您已安装git并拥有帐户 使用Spring Boot创建一个简单的Web API 了解Spring Actuator提供给您的应用程序度量标准 先决条件 有用的知识: Spring框架/核心 Spring网 吉特 您当地的环境和...

    paraviewweb:Web框架,用于依靠VTK或ParaView构建交互式可视化以生成可视化数据

    ParaViewWeb旨在提供一个框架来构建依赖VTK或ParaView生成可视化数据的交互式Web可视化。 这些数据可以是静态的也可以是动态的,范围从无服务器设置到具有ParaView或VTK后端将几何图形或图像发送到客户端的范围。 ...

Global site tag (gtag.js) - Google Analytics