我可以在以前的所有提交中更改我的名字和姓氏吗?


122

我想在所有提交中更改我的姓名,姓氏和电子邮件,可以吗?


2
它是只为您,为几个人还是为一个大型项目提供的礼物?
thejh 2010年



Answers:


212

使用git-filter-branch

git filter-branch --commit-filter 'if [ "$GIT_AUTHOR_NAME" = "Josh Lee" ];
  then export GIT_AUTHOR_NAME="Hobo Bob"; export GIT_AUTHOR_EMAIL=hobo@example.com;
  fi; git commit-tree "$@"'

这仅影响作者,而不影响提交者(对于大多数提交,该提交者将与作者相同)。如果您也想重写它们,请设置GIT_COMMITTER_NAMEGIT_COMMITTER_EMAIL变量。

有关重写历史记录的标准警告适用;仅对尚未共享的历史记录执行此操作。

2018年6月更新

手册现在--env-filter在示例中包含使用的解决方案:https : //git-scm.com/docs/git-filter-branch#_examples

git filter-branch --env-filter '
    if test "$GIT_AUTHOR_EMAIL" = "root@localhost"
    then
        GIT_AUTHOR_EMAIL=john@example.com
    fi
    if test "$GIT_COMMITTER_EMAIL" = "root@localhost"
    then
        GIT_COMMITTER_EMAIL=john@example.com
    fi
' -- --all

4
如果您正在使用msysgit,您仍然可以访问bash。否则,我毫无头绪。
Josh Lee 2010年

@Joshua,如果您正在使用没有bash的内容,则可以使用Windows批处理脚本,尽管我没有尝试过。
MatrixFrog 2010年

标签呢?此解决方案不会更改标签的作者
piotrek 2015年

@Joshua在Linux机器上签出git repo并在那里进行修复
Will Sheppard

是否有导致新分支并保持源提交完整的选项?
Eugen Konkov

56

要在所有选定的提交中重写作者和提交者:

git filter-branch --commit-filter \
'if [ "$GIT_AUTHOR_NAME" = "OldAuthor Name" ]; then \
export GIT_AUTHOR_NAME="Author Name";\
export GIT_AUTHOR_EMAIL=authorEmail@example.com;\
export GIT_COMMITTER_NAME="Commmiter Name";\
export GIT_COMMITTER_EMAIL=commiterEmail@example.com;\
fi;\
git commit-tree "$@"'

1
但是如何将更改应用于远程服务器?
维凯德

5
@Viky Trygit push --all origin --force
user11153 '17

2
这个对我有用 !我正在使用GitLab,必须在执行push命令之前取消保护分支。
vikyd

37

如果没有其他作者,则可以执行以下操作:

git filter-branch --commit-filter 'export GIT_AUTHOR_NAME="authorname"; \
export GIT_AUTHOR_EMAIL=mail@example.com; git commit-tree "$@"'

1
它不是在重写“提交者:”信息。
user11153 2014年

1
它不打算重写提交者信息。如果要执行此操作,请同时导出GIT_COMMITTER_NAME和GIT_COMMITTER_EMAIL(请参见接受的答案)。
chronospoon 2014年

12

将以下脚本另存为例如~/.bin/git-replace-author,并使用例如运行它:

git replace-author "John Ssmith" "John Smith" "johnsmith@example.com"

不带任何参数,它将根据您的名称更新所有提交,以根据Git配置使用您当前的电子邮件地址。

DEFAULT_NAME="$(git config user.name)"
DEFAULT_EMAIL="$(git config user.email)"
export OLD_NAME="${1:-$DEFAULT_NAME}"
export NEW_NAME="${2:-$DEFAULT_NAME}"
export NEW_EMAIL="${3:-$DEFAULT_EMAIL}"

echo "Old:" $OLD_NAME "<*>"
echo "New:" "$NEW_NAME <$NEW_EMAIL>"
echo "To undo, use: git reset $(git rev-parse HEAD)"

git filter-branch --env-filter \
'if [ "$GIT_AUTHOR_NAME" = "${OLD_NAME}" ]; then
    export GIT_AUTHOR_NAME="${NEW_NAME}"
    export GIT_AUTHOR_EMAIL="${NEW_EMAIL}"
    export GIT_COMMITTER_NAME="${NEW_NAME}"
    export GIT_COMMITTER_EMAIL="${NEW_EMAIL}"
fi'

原始(下载)


简而言之::~/.bin/必须位于用户内部$PATH,文件必须是可执行文件,因此运行:chmod +x ~/.bin/git-replace-author
Michael Gecht

以及参数如何处理?
Eugen Konkov

2

仅在您尚未将承诺推向世界时。否则,其他所有人的回购中都会有您的旧名字,这不太可能改变您所有人的名字。


是的,但是在某些情况下您别无选择。我的情况是我在git config中配置了错误的电子邮件地址(就像我在“ git config --global -l”中看到的那样)。结果,我没有在自己的Github存储库中显示提交活动(因为电子邮件地址与Github中配置的电子邮件不匹配)!为了解决这个问题,我使用stackoverflow.com/a/23564785/2474068上的配方修复了本地提交(完美工作),然后使用“ git push -u -f origin master”将更改的提交推送到了Github(用力标志“ -f”)。这违背了公认的惯例,但我别无选择!
leo

1
是的,我的意思是,该回购协议的任何分支都不会进行更改,除非他们接受了您的强力推动。使每个分叉都更新将是一个挑战:)
EnabrenTane

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.