Git骚操作

本文提供了结合oh-my-zsh和gitplugin使用的Git命令别名,包括整理分支commit记录、合并分支、推送分支、cherry-pick等操作的具体命令示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以下快捷操作配合 oh-my-zsh + git plugin 一并食用,效率更佳

Git Aliases

整理功能分支冗余commit记录 -> rebase

# git checkout
gco <branch-name>

# git rebase -i commit-hash
grbi $(g merge-base $(current_branch)  master)

# Commands:
# p, pick = 使用commit 包括commit message
# r, reword = 使用commit, 但是会弹出交互式界面要求你重新编辑该条commit message
# e, edit = 使用commit, 但是会中断rebase,使用 git commit --amend 编辑该条commit message; 使用 git rebase --continue 继续
# s, squash = 使用commit, 但是会弹出交互式界面要求你重新编辑该条commit message,会同时显示上一条commit message
# f, fixup = 将此commit合并入上个commit, 并且抛弃commit message
# x, exec = 执行之后的命令, 如果执行失败则中断rebase, 使用git rebase --continue 继续, 会抛弃该条commit!
# d, drop = 抛弃该条commit

键入 i 开始修改,修改 commit-hash 前置命令完成后 键入 esc -> : -> w -> q -> enter 保存退出即可
复制代码

整理功能分支冗余commit记录 -> reset

gco <branch-name>

glol

复制回退的第一个功能提交之前的 commit-hash

# 千万不要加--hard,会把工作区的记录一并清掉!!
git reset <commit-hash>

# git add --all
gaa

# git commit -m
gcmsg 'commit message'
复制代码

合并master commit至功能分支

# git rebase master
grbm
复制代码

强制推送本地分支至远程同名分支

# git push --force origin $(current_branch)
ggf
复制代码

推送本地分支至远程(远程未创建该分支)

# git push --set-upstream origin $(current_branch)
gpsup
复制代码

cherry-pick -> 单 commit

gco <origin-branch-name>

# git log --graph --pretty = format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit
glol

复制想要的commit-hash

gco <target-branch-name>

# git cherry-pick
gcp <commit-hash>
复制代码

cherry-pick -> 多 commit

# 左开右闭,不包含start-commit-id
gcp <start-commit-id>..<end-commit-id>

# 闭区间,包含start-commit-id
gcp <start-commit-id>^..<end-commit-id>
复制代码

将当前commit修改合并至上一个commit

git commit -a -amend

# git commit -v -a -s --no-edit --amend
gcan!
复制代码

查看操作记录(仅限本地)

git reflog
复制代码

拉取master代码

# git pull --rebase
gup
复制代码

删除已合并分支

# git branch --merged | command grep -vE "^(*|\smaster\s$)" | command xargs -n 1 git branch -d
gbda
复制代码

转载于:https://juejin.im/post/5a7d4b685188257a856f341b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值