以前のすべてのコミットで自分の名前と姓を変更できますか?


122

すべてのコミットで名前、姓、電子メールを変更したいのですが、可能ですか?


2
それはあなただけの、数人の人々のための、または大きなプロジェクトのための再現ですか?
thejh



回答:


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_NAMEおよびGIT_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

@Joshua bashがない場所で何かを使用している場合は、おそらくWindowsバッチスクリプトを使用できますが、私は試していません。
MatrixFrog 2010

タグについてはどうですか?このソリューションはタグの
作成

@JoshuaがLinuxボックスでgitリポジトリをチェックして、そこで修正を実行します
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
しかし、リモートサーバーに変更を適用する方法は?
vikyd 2017年

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

2
わたしにはできる !私はGitLabを使用していますが、pushコマンドの前にブランチの保護を解除する必要があります。
vikyd 2017年

37

他に著者がいない場合は、次のことができます。

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

1
「Committer:」情報を書き換えているわけではありません。
user11153 2014年

1
コミッター情報を書き換えることを意図したものではありません。それを行う場合は、GIT_COMMITTER_NAMEとGIT_COMMITTER_EMAILもエクスポートします(承認された回答を参照)。
クロノスプーン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
マイケル・ゲヒト

そしてそれは引数で何をしますか?
Eugen Konkov

2

コミットを世界にプッシュしていない場合のみ。それ以外の場合は、他のすべての人がリポジトリに古い名前を持っているため、全員の名前を変更することはできません。


本当ですが、場合によっては選択の余地がありません。私の場合、git configで間違ったメールアドレスが設定されていました( "git config --global -l"で確認できます)。その結果、自分のGithubリポジトリにコミットアクティビティが表示されませんでした(メールアドレスがGithubで構成されたメールと一致しなかったため)!これを解決するために、stackoverflow.com / a / 23564785/2474068からのレシピを使用してローカルコミットを修正し(完全に機能)、次に「git push -u -f origin master」を使用して変更されたコミットをGithubにプッシュしました(強制フラグ「-f」)。それは認められた慣行に反しますが、私には選択肢がありませんでした!
2016年

1
はい、私の要点は、そのレポのフォークは、彼らがあなたのフォースプッシュを受け入れない限り、その変更を持たないということです。すべてのフォークを更新するのは難しいでしょう:)
EnabrenTane 2016年

1

Git 2.24(2019年第4四半期)では、git filter-branch(およびBFG)は非推奨です

同等のものは、を使用しnewren/git-filter-repo、その例のセクションです。

cd repo
git filter-repo --mailmap my-mailmap

my-mailmap

Correct Name <correct@email.com> <old@email.com>

それは誰でもが行ったコミットの著者名と電子メールを <old@email.com>

の正確な構文については、git shortlogマッピング作成者のセクションを参照してください

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.