博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[翻译] 10 个实用的 Git 高级命令
阅读量:5104 次
发布时间:2019-06-13

本文共 1934 字,大约阅读时间需要 6 分钟。

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) # 输出2个提交间的改变#

3. 克隆 指定的远程分支

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

git initgit remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HEREgit 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

 

 

原文:

转载于:https://www.cnblogs.com/52php/p/6603497.html

你可能感兴趣的文章
如何终止线程的运行(C/C++)
查看>>
"远程桌面连接--“发生身份验证错误。要求的函数不受支持
查看>>
【BZOJ1565】 植物大战僵尸
查看>>
视频:"我是设计师"高清完整版Plus拍摄花絮
查看>>
sicp solutions
查看>>
VALSE2019总结(4)-主题报告
查看>>
浅谈 unix, linux, ios, android 区别和联系
查看>>
PhotoZoom放大图片,真的能无损吗?
查看>>
转载分享移动网站最佳实践
查看>>
spark--环境搭建--4.ZooKeeper345集群搭建
查看>>
Codeforces Round #426 (Div. 2) C. The Meaningless Game
查看>>
51nod 1428 活动安排问题 (贪心+优先队列)
查看>>
leetcode - Next Permutation
查看>>
C#创建Windows服务程序
查看>>
Spring Boot 2.0系列文章(五):Spring Boot 2.0 项目源码结构预览
查看>>
中国烧鹅系列:利用烧鹅自动执行SD卡上的自定义程序(含视频)
查看>>
Solaris11修改主机名
查看>>
latex for wordpress(一)
查看>>
如何在maven工程中加载oracle驱动
查看>>
Flask 系列之 SQLAlchemy
查看>>