最终解决方法来源:
https://segmentfault.com/q/1010000006999861
https://www.cnblogs.com/zh7791/p/12986083.html
①
git rebase -i HEAD~N
N代表前N次的提交记录
②
出现记录后键入i进入INSERT模式,在需要修改的条目上,将pick改为edit;按esc退出编辑,按shift+;后输入wq!退出。
③
git commit --amend --author=“用户名 <邮箱>” --no-edit
输入需要更改的用户名与邮箱
④
git rebase --continue
然后 push 上去就可以了。
⑤
另:批量处理的方法:
git filter-branch --force --env-filter '
#如果Git用户名等于老的Git用户名
if [ "$GIT_COMMITTER_NAME" = "<Old Name>" || "$GIT_AUTHOR_EMAIL" = "<Old Email>" ];
then
#替换提交的用户名为新的用户名,替换提交的邮箱为正确的邮箱
GIT_COMMITTER_NAME="<New name>";
GIT_COMMITTER_EMAIL="<New email>";
#替换用户名为新的用户名,替换邮箱为正确的邮箱
GIT_AUTHOR_NAME="<New name>";
GIT_AUTHOR_EMAIL="<New email>";
fi
' --tag-name-filter cat -- --all
这篇博客介绍了如何通过Git的交互式重置(i-rebase)和filter-branch命令来修改最近N次提交的作者信息,包括将旧的用户名和邮箱替换为新的。步骤包括选择要修改的提交,使用git commit --amend更新信息,然后继续rebase流程。此外,还提供了批量处理所有历史提交的方法。
21万+

被折叠的 条评论
为什么被折叠?



