検索
ホームページ開発ツールGitgitの履歴を変更する方法

方法: 1. "git commit --amend" コマンドを使用して 1 つの履歴レコードを変更します。 2. "git rebase -i specific submitnumber" コマンドを使用して複数の履歴レコードを変更します。 3. " git filter-「branch --filer command」コマンドで変更された範囲は履歴を書き換えます。

gitの履歴を変更する方法

この記事の動作環境: Windows 10 システム、Git バージョン 2.30.0、Dell G3 コンピューター。

git の履歴を変更する方法

ジュニア プレイヤー git amend

次の場合後で、自分に障害があることがわかったので、 git commit --amend を使用して前のコミットを変更しました。このコマンドが実行されると、現在のブランチから以前のコミットが削除され、ワー​​クスペースが送信の準備が最後に行われた状態に復元され (最後のコミット後の変更を混合しながら)、vim インターフェイスが表示されます。そして最後のコミット情報を変更します。 vim で保存すると、現在のすべての変更が新しい送信情報とともに送信されます。

このコマンドは最後のコミットのみを変更できます。1 つのコマンドは、次の一連のアクションを実行するのと同等です:

    $ORIG_HEAD=`git show`#保存当前的这次提交的 commit 号
    $git reset --soft HEAD^#回到最后一次提交准备提交前的状态
    $...#做一些操作和修改
    $git commit -c $ORIG_HEAD#表示用最后一次提交的提交信息来做为提交信息,不过会调出编辑器界面

中級プレイヤー git rebase

前へ git commit --amend は最後のコミットのみを変更できますが、気まぐれでずっとハンディキャップを負っているときは、このコマンドでは救われません。現時点では、git rebase -i というキラー ツールを使用する必要があります。 help 振り返るには耐えられない過去の出来事を見直します。

実際には、 git rebase -i は履歴レコードを変更するために特別に使用されるコマンドではなく、リベース操作を対話的に (つまり 1 つずつ) 実行できるようにするコマンドですが、このコマンドを使用できます。コミット履歴を変更するために使用されます。

このコマンドの使用方法は、 git rebase -i です。たとえば、 git rebase -i HEAD~3 を使用して、この提出、最後の提出、および前の提出を変更できます。合計3回提出します。

gitの履歴を変更する方法

図に示すように、変更を 3 回送信して git rebase -i HEAD~3 と入力すると、次のインターフェイスが表示されます。

gitの履歴を変更する方法これは vim エディター インターフェイスです。このスクリプトを編集してみましょう。使用できるコマンドは、以下のコメント内の 6 つのコマンドです。現在編集中のページを終了すると、git はこのスクリプトに従って (最も古い送信から開始して) 送信に対して 1 つずつ対応する操作を実行します。

投稿情報を修正したいだけの場合は、すべての pick を r に変更して、wq で保存すると、git で古い投稿情報から順に 1 つずつ変更できます。

残りのコマンドのうち、e は、対応する送信を変更するときに vim エディターから飛び出します。このとき、HEAD ポインターはこの送信を指します。このとき、 git commit --amend を使用して、この送信にさまざまな変更を加え、 git rebase -- continue を実行して次の操作を続行します。 s は、対応する送信を変更するときに、この送信とその親の送信を 1 つの送信にマージします。 f は s に似ていますが、現在の送信を無視します。情報。親によって送信された情報を直接使用します。x では、x の後にコマンドを入力し、HEAD がこの送信を指すときにコマンドを実行する必要があります。これらのコマンドを使用して、送信を並べ替えたり、送信を分割したりすることもできます。

究極のキラー git filter-branch

N 回送信した後、送信したメール アドレスがすべて間違っていたことに突然気づいたとします (╯°□° )╯︵ ┻━┻、この時点で前述のコマンドを使用すると、変更が完了する前に力尽きてしまう可能性がありますが、この時点で git filter-branch を使用してブランチを書き換えることができ、各ブランチをバッチ処理できます。

git filter-branch コマンドで使用される基本的な使用形式は git filter-branch -- 'コマンド' であり、フィルターが異なれば提供される内容も異なります。たとえば、 --msg-filter は送信情報を変更することを意味し、元の送信情報は標準入力から読み取られ、新しい送信情報は標準出力に出力されます。 --tree-filter は、送信情報を変更することを意味します。ファイル リストの変更など 最後に、書き換えのスコープが存在します。たとえば、 git filter-branch --env-filter 'GIT_AUTHOR_EMAIL=john@example.com export GIT_AUTHOR_EMAIL' HEAD を使用してメールボックスを書き換えることができますコマンドを呼び出す前にこれを出力することをお勧めします ブランチを 1 つ試してから、変更したいブランチで操作を実行します。

推奨学習: "

Git チュートリアル

"

以上がgitの履歴を変更する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Git vs. Github:彼らの役割を探るGit vs. Github:彼らの役割を探るApr 16, 2025 am 12:06 AM

GitとGithubは異なるツールです。Gitは、コードバージョンと共同開発を管理するための分散バージョン制御システムです。 GitHubは、Gitに基づいたオンラインプラットフォームであり、コードホスティングおよびコラボレーションツールを提供しています。 GITの主な機能には、バージョン管理、支店管理、コラボレーション開発が含まれ、GitHubはコードホスティング、コラボレーションツール、ソーシャルネットワーキング機能を提供します。

Github:オープンソースとソフトウェア開発のハブGithub:オープンソースとソフトウェア開発のハブApr 15, 2025 am 12:10 AM

GitHubは、バージョン制御、共同開発、コミュニティコミュニケーション機能を提供するGitベースのバージョン制御システムホスティングプラットフォームです。 GitHubを使用すると、開発効率とコードの品質が向上する可能性があります。

Git and Github:関係は何ですか?Git and Github:関係は何ですか?Apr 14, 2025 am 12:10 AM

GitとGithubは異なるツールです。Gitはバージョン制御用のソフトウェアであり、GithubはGitに基づくオンラインプラットフォームです。 1.GITを使用すると、ファイルの変更と共同開発を追跡できます。 2。Githubは、チーム開発効率を高めるためのコードホスティングおよびコラボレーションツールを提供します。

Github:開発者とプロジェクトのためのプラットフォームGithub:開発者とプロジェクトのためのプラットフォームApr 13, 2025 am 12:01 AM

GitHubのコア機能には、バージョン制御、支店管理、コードレビュー、問題追跡、プロジェクト管理が含まれます。 1。バージョン制御とブランチ管理はGITに基づいており、コードの変更と実験開発の追跡を可能にします。 2。コードレビューは、PullRequestを通じて実装され、コードの品質とチームコラボレーションを改善します。 3.問題の追跡とプロジェクト管理は、プロジェクトの透明性とトレーサビリティを改善するために、問題とプロジェクト管理委員会を通じて実行されます。

github in Action:例とユースケースgithub in Action:例とユースケースApr 12, 2025 am 12:16 AM

GitHubは、ソフトウェア開発の効率と品質を向上させるための強力なツールです。 1)バージョン制御:GITを介してコードの変更を管理します。 2)PullRequests:コードレビューを実施し、コードの品質を改善します。 3)問題:バグとプロジェクトの進捗を追跡します。 4)githubactions:建設、テスト、展開プロセスを自動化します。

Git vs. Github:バージョンコントロールとコードホスティングGit vs. Github:バージョンコントロールとコードホスティングApr 11, 2025 am 11:33 AM

Gitはバージョン制御システムであり、GithubはGitベースのコードホスティングプラットフォームです。 GITは、コードバージョンを管理し、ローカル操作をサポートするために使用されます。 GitHubは、問題の追跡やPullRequestなどのオンラインコラボレーションツールを提供しています。

簡単な言葉でGitとは何ですか?簡単な言葉でGitとは何ですか?Apr 09, 2025 am 12:12 AM

GITは、開発者がファイルの変更を追跡し、協力してコードバージョンを管理するのに役立つオープンソース分散バージョン制御システムです。そのコア関数には、1)レコードコードの変更、2)以前のバージョンへのフォールバック、3)共同開発、4)並列開発のためのブランチの作成と管理。

gitはgithubと同じですか?gitはgithubと同じですか?Apr 08, 2025 am 12:13 AM

gitとgithubは同じものではありません。 Gitはバージョン制御システムであり、GithubはGitベースのコードホスティングプラットフォームです。 GITはコードバージョンの管理に使用され、GitHubはオンラインコラボレーション環境を提供します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター