前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >你可能不知道的15个 Git 命令[每日前端夜话0xF5]

你可能不知道的15个 Git 命令[每日前端夜话0xF5]

作者头像
疯狂的技术宅
发布2019-12-11 10:58:29
7870
发布2019-12-11 10:58:29
举报
文章被收录于专栏:京程一灯

正文共:3616 字

预计阅读时间:8 分钟

翻译:疯狂的技术宅 作者:zaiste 来源:zaiste.net

Git 有时可能会令人生畏。因为有太多的命令和细节需要学习。不过虽然文档的内容很多,但阅读起来还是很轻松的。一旦你克服了最初不堪重负的感觉,就会感觉到有明显进展。以下是你可能还不知道的 15 个 Git 命令的列表,希望它们能帮助你熟练掌握Git。

1.修改最近的提交

代码语言:javascript
复制
git commit --amend

—-amend 允许你把阶段性更改(例如添加被遗忘的文件)附加到上一次提交。添加 --no-edit 将会修改最后的提交但不更改它的提交消息。如果没有更改,--amend 将允许你重新输入最后的提交消息。

更多信息:git help commit

2.以交互方式添加文件的选定部分

代码语言:javascript
复制
git add -p

-p (或 —patch) 允许以交互的形式选择每个跟踪文件中要提交的部分。这样每次提交仅包含相关的更改。

更多信息:git help add

3.以交互方式隐藏文件的选定部分

代码语言:javascript
复制
git stash -p

git-add 类似,你可以使用 --patch 选项以交互方式选择每个要跟踪文件的部分。

更多信息:git help stash

4.隐藏未跟踪的文件

代码语言:javascript
复制
git stash -u

在默认情况下,存储时不包括那些未跟踪的文件。为了改变这种行为并包括那些文件,你需要使用 -u 参数。还有一个 -a-all)参数可以存储所有未跟踪和忽略的文件,这种操作通常能是你不需要的。

5.以交互方式还原文件的选定部分

代码语言:javascript
复制
git checkout -p
--patch` can be also used to selectively discard parts of each tracked file. I aliased this command as `git discard

更多信息:git help checkout

6.切换到上一个分支

代码语言:javascript
复制
git checkout -

此命令使你可以快速切换到先前签出的分支。通常 - 是上一个分支的别名。它也可以与其他命令一起使用。我为 checkout 创建了一个别名 co,因此可以是 git co -

7.恢复所有本地更改

代码语言:javascript
复制
git checkout .

如果你确定可以放弃本地所有更改,则可以用 . 一次完成。但是始终使用 checkout --patch 是一个好习惯。

8.显示更改

代码语言:javascript
复制
git diff --staged

该命令显示所有已阶段化的更改(已添加到索引中的更改),而与 git diff 相比,后者仅显示工作目录中的更改(索引中没有更改)。

更多信息:git help diff

9.在本地重命名分支

代码语言:javascript
复制
git branch -m old-name new-name

如果要重命名当前签出的分支,可以将命令缩短为以下形式:

代码语言:javascript
复制
git branch -m new-name

更多信息:git help branch

10.远程重命名分支

为了远程重命名分支,在本地重命名分支后,你需要先远程删除该分支,然后再次推送重命名的分支。

代码语言:javascript
复制
git push origin :old-name
git push origin new-name

11.一次打开所有有冲突的文件

重新设置基准可能会导致冲突,以下命令将打开需要你解决这些冲突的所有文件。

代码语言:javascript
复制
git diff --name-only --diff-filter=U | uniq  | xargs $EDITOR

12.发生了什么变化?

代码语言:javascript
复制
git whatchanged —-since=‘2 weeks ago’

该命令将显示一个日志,其中包含最近两周内每次提交所引入的差异。

13.从上一次提交中删除文件

你可以通过结合 rmcommit --amend 命令来从上一次提交中快速删除误提交的文件:

代码语言:javascript
复制
git rm —-cached <file-to-remove>
git commit —-amend

14.查找分支

代码语言:javascript
复制
git branch --contains <commit>

该命令将显示包含特定提交的所有分支。

15.在本地优化存储库

代码语言:javascript
复制
git gc --prune=now --aggressive

更多信息:git help gc

总结

尽管我非常喜欢CLI,但还是强烈建议使用 Magit 来进一步提高你使用 Git 的效率。它是我用过的最好的软件之一。

也可以通过 help 命令查看 Git 工作流程的精彩概述。请务必仔细阅读!

代码语言:javascript
复制
git help workflows

原文:https://zaiste.net/15-git-commands-you-may-not-know/

在公众号内回复“体系”查看高清大图

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-12-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端先锋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.修改最近的提交
  • 2.以交互方式添加文件的选定部分
  • 3.以交互方式隐藏文件的选定部分
  • 4.隐藏未跟踪的文件
  • 5.以交互方式还原文件的选定部分
  • 6.切换到上一个分支
  • 7.恢复所有本地更改
  • 8.显示更改
  • 9.在本地重命名分支
  • 10.远程重命名分支
  • 11.一次打开所有有冲突的文件
  • 12.发生了什么变化?
  • 13.从上一次提交中删除文件
  • 14.查找分支
  • 15.在本地优化存储库
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档