GIT高级使用技巧

GIT高级使用技巧

导出GIT日志到文件

按照 <哈希> - <作者名> <作者邮箱地址> - <作者日期> : <commit描述> 的格式导出日志

Bash 复制代码
git log --pretty=format:"%H - %an <%ae> - %ad : %s" master > log.txt

筛选日志并按照从旧到新的顺序排序,且只要提交哈希值(用于批量cherry-pick等操作)

Bash 复制代码
cat log.txt | grep <匹配关键字> | awk '{print $1}' | tac

批量git cherry-pick

要批量应用 git cherry-pick 命令,可以使用 xargs配合 git cherry-pick 使用。具体步骤如下:

  1. 将要应用的提交 ID 复制到一个文本文件中,每行一个提交 ID。
  2. 执行以下命令:
Bash 复制代码
cat file.txt | xargs git cherry-pick <options>

options 可以是 -m 1 ,意思是遇到merge commit的时候,因为merge commit会有多个parent,需要选择以哪个parent为主。-m 1 是指以第一个parent为主。如果不指定该选项,遇到merge commit会报错中断。

当使用 git cherry-pick 命令批量应用提交时,可能会发生冲突。如果发生冲突,Git 会停止应用提交,并提示您解决冲突。在解决冲突后,您需要继续应用剩余的提交。可以使用 git cherry-pick --continue 命令来继续应用提交,或者使用 git cherry-pick --abort 命令取消应用提交。

查看删除文件的历史记录

用以下命令去查看改名或者删除某个文件的commit。

Bash 复制代码
git log --follow --diff-filter=RD --full-history <分支名> -- <文件路径>

git log会从分支的HEAD节点往上回溯,找到所有符合条件的commit。

强行更新submodules

submodules的内容有时候会丢失,但是却无法补全,执行git submodule update --init --recursive也无效。这时候需要强制更新 -f

Bash 复制代码
git submodule update --init --recursive -f

查看某个文件从某个点开始回溯的历史变动路径

用以下命令打开gitk图形用户界面。

Bash 复制代码
gitk <分支/tag/commit> <文件路径>
相关推荐
Beyond欣32 分钟前
Git 踩坑记录
git
没有bug.的程序员2 小时前
分布式配置深潜:Spring Cloud Config 与 Git 集成内核、版本回滚机制与多环境治理实战指南
java·分布式·git·spring cloud·分布式配置·版本回滚
JTfAbUGXr4 小时前
Smart200PL与42块安科瑞多功能电度表Modbus RTU通讯程序探索
git
Beyond欣5 小时前
Git 配置与工具
大数据·git·elasticsearch
xuhe215 小时前
Claude Code配合Astro + GitHub Pages:为 sharelatex-ce 打造现代化的开源项目宣传页
linux·git·docker·github·浏览器·overleaf
西门吹-禅16 小时前
git 使用
git
前路不黑暗@1 天前
Java项目:Java脚手架项目的模板服务和网关服务的实现(三)
java·开发语言·spring boot·git·学习·spring cloud·maven
贡献者手册1 天前
当 AI 写代码的速度超过了你提交的速度:为何你需要一款“流式” Git 管理器?
人工智能·git
NGC_66111 天前
idea中使用git
java·git·intellij-idea
承渊政道1 天前
Linux系统学习【深入剖析Git的原理和使用(上)】
linux·服务器·git·学习