10 个很有用的高级 Git 下令

打印 上一主题 下一主题

主题 880|帖子 880|积分 2640

10 个很有用的高级 Git 下令

迄今,我已经利用Git很长一段时间了,思量分享一些不管你是团队开发还是个人项目,都受用的高级git下令。
1. 输出最后一次提交的改变

这个下令,我经常利用它 来发送其他没有利用git的人来查抄或者集成所修改的。它会输出近来提交的修改内容到一个zip文件中。
  1. git archive -o ../updated.zip HEAD $(git diff --name-only HEAD^)
复制代码

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

类似的,如果你需要输出某两个提交间的改变时,你可以利用这个。
  1. git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff --name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)
复制代码


3. 克隆 指定的远程分支

如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你资助很大。
  1. git init
  2. git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
  3. git checkout BRANCH_NAME_HERE
复制代码
4. 应用 从不相干的本地仓库来的补丁

如果你需要其它一些不相干的本地仓库作为你如今仓库的补丁,这里就是通往那里的捷径。
  1. 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)。.+ 指示没有出如今所给分支中,反之,- 就表示出如今了所给的分支中了。这里就是怎样去检测:
  1. git cherry -v OTHER_BRANCH_NAME_HERE
  2. #例如: 检测master分支
  3. git cherry -v master
复制代码


6.开始一个无汗青的新分支

偶然,你需要开始一个新分支,但是又不想把很长很长的汗青记录带进来,比方,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的汗青记录。
  1. git checkout --orphan NEW_BRANCH_NAME_HERE
复制代码
7. 无切换分支的从其它分支Checkout文件

不想切换分支,但是又想从其它分支中获得你需要的文件:
  1. git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE
复制代码


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

如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有大概会经常用到fetch和merge。但是偶然间这样会重置您的环境设置文件,如此的话,您就得在每次merge后修改它。利用这一下令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。
  1. git update-index --assume-unchanged PATH_TO_FILE_HERE
复制代码
9.查抄提交的变动是否是release的一部分

name-rev下令能告诉您一个commit相对于近来一次release的位置。利用这条下令,您就可以查抄您所做出的改动是否是release的一部分了。
  1. git name-rev --name-only COMMIT_HASH_HERE
复制代码
10.利用rebase推送而非merge

如果您正在团队中工作而且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时间利用rebase,以此来减少无用的merge消息,从而保持汗青记录的清晰。
  1. git pull --rebase
复制代码
您也可以将某条branch设置为总是利用rebase推送:
  1. git config branch.BRANCH_NAME_HERE.rebase true
复制代码
本文地址:10 个很有用的高级 Git 下令 - OSCHINA - 中文开源技能交流社区
原文地址:http://webdeveloperplus.com/general/10-useful-advanced-git-commands/
本文中的全部译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时接洽我们

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

愛在花開的季節

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表