Git 修改已提交 commit 的信息

修改最后一次提交 commit 的信息

# 修改最近提交的 commit 信息
$ git commit --amend --message="XXX" --author="XXX <XXX@XX.com>"

# 仅修改 message 信息
$ git commit --amend --message="XXX"

# 仅修改 author 信息
$ git commit --amend --author="XXX <XXX@XX.com>"

修改历史提交 commit 的信息

操作步骤:

  1. git rebase -i 列出 commit 列表
  2. 找到需要修改的 commit 记录,把 pick 修改为 edite:wq 保存退出
  3. 修改 commit 的具体信息git commit --amend,保存并继续下一条git rebase --continue,直到全部完成
  4. 中间也可跳过或退出git rebase (--skip | --abort)
 # 列出 rebase 的 commit 列表,不包含 <commit id>
 $ git rebase -i <commit id>
 # 最近 3 条
 $ git rebase -i HEAD~3
 # 本地仓库没 push 到远程仓库的 commit 信息
 $ git rebase -i
 
 # vi 下,找到需要修改的 commit 记录,```pick``` 修改为 ```edit``` 或 ```e```,```:wq``` 保存退出
 # 重复执行如下命令直到完成
 $ git commit --amend --message="modify message by daodaotest" --author="XXX <XXX@163.com>"
 $ git rebase --continue
 
 # 中间也可跳过或退出 rebase 模式
 $ git rebase --skip
 $ git rebase --abort 

批量修改历史 commit 信息

创建批量脚本changeCommit.sh

$ cat changeCommit.sh
#!/bin/sh

git filter-branch --env-filter '

# 之前的邮箱
OLD_EMAIL="XXX@XX.com"
# 修改后的用户名
CORRECT_NAME="XXX"
# 修改后的邮箱
 CORRECT_EMAIL="XXX@XX.com"
 
if [ "$GIT_COMMITTER_EMAIL" = "$OLD_EMAIL" ]
then
     export GIT_COMMITTER_NAME="$CORRECT_NAME"
     export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
 fi
 if [ "$GIT_AUTHOR_EMAIL" = "$OLD_EMAIL" ]
 then
     export GIT_AUTHOR_NAME="$CORRECT_NAME"
     export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
 fi
 ' --tag-name-filter cat -- --branches --tags

执行脚本成功后,强制推送到远程服务器

$ git push --force --tags origin 'refs/heads/*'

 

转自:https://cloud.tencent.com/developer/article/1730774

posted @ 2022-07-08 11:28  karila  阅读(2307)  评论(0编辑  收藏  举报