Gitのコマンドをまとめてみた

更新日 : 2023/8/16

今更ですが、Gitについて最近学び直しているので備忘メモとして簡単にまとめます。 雑ですがコマンド以外のメモも残します。

それではいきます。

Gitコマンドまとめ

▼Gitユーザー名の登録

$ git config --global user.name "任意のユーザー名"

▼Gitユーザーのメールアドレスの登録

$ git config --global user.email 任意のメールアドレス

▼Gitの設定一覧表示

$ git config --list
このコマンドで表示される内容の設定ファイルは「~/.gitconfig」に記載されていて、ファイルの中身はcatコマンドなどで確認できます。

▼ワークツリーの変更をステージへ追加(=ステージにインデックスを作成)

$ git add <ファイル名>

▼現在のファイル変更状況を確認

$ git status
ワークツリーとステージの差分は赤色の文字で、ステージとローカルリポジトリの差分は緑色の文字で表示されます。

▼ワークツリーとステージの変更差分を確認

$ git diff
ステージとローカルリポジトリの変更差分を確認する場合は、以下のコマンドを使用します。

▼ステージとローカルリポジトリの変更差分を確認

$ git diff --staged

▼変更(コミット)履歴を確認

$ git log

▼変更(コミット)履歴を一行ずつで確認

$ git log --oneline

▼変更(コミット)履歴の変更差分のみを確認

$ git log -p
「-p」の後ろにスペースを開けて、ファイル名を追加することで特定のファイルに絞って確認することができます。

▼変更(コミット)履歴を表示数を制限して確認

$ git log -n コミット数

▼ワークツリーとローカルリポジトリの両方からファイル(またはディレクトリ)を削除

$ git rm ファイル名(またはディレクトリ名)

▼ローカルリポジトリからのみファイル(またはディレクトリ)を削除

$ git rm --cached ファイル名(またはディレクトリ名)

▼ファイルを移動(またはリネーム)

$ git mv 旧ファイル名 新ファイル名
上のmvコマンドを実行すると、ワークツリーだけでなくステージにも変更が反映された状態になります。すなわち、変更後git addした状態になるということです。
ディレクトリを移動する場合は、ファイル名の部分にディレクトリパスを入力すれば可能です。

▼ローカルPCのディレクトリをリモートリポジトリへ登録

$ git remote add origin リモートリポジトリのURL
「git remote add」の部分でリモートリポジトリを登録して、その後の「origin」で今後使用するリモートリポジトリの省略名を設定します。
また、使う機会はあまりないかもしれませんが、複数のリモートリポジトリを設定することもできます。

▼リモートリポジトリに変更を反映

$ git push リモート名 ブランチ名
リモート名は「origin」が一般的かと思います。

▼Gitコマンドにエイリアスを登録

$ git config --global alias.エイリアス名 エイリアス登録するコマンド
例としては、「git config --global alias.co commit」のような感じです。
「--global」をつけた場合は、ホームディレクトリ配下の「~/.gitconfig」ファイルに設定が反映されます。
「--global」をつけない場合は、コマンドを実行した際にいるプロジェクトの「.git/config」ファイルに設定が反映されます。

▼ワークツリーの変更を取り消す(=ステージの状態に戻す)

$ git checkout -- ファイル名(またはディレクトリ名)
「checkout」コマンドはブランチを切り替える時にも使用しますが、ブランチの切り替えなのか、ファイルの変更取り消しなのかを区別するために「--」がついています。
また、前回のaddコマンド実行時からの全ファイルの変更を取り消したい場合は、「git checkout -- .」のコマンドで取り消すことができます。

▼ステージに追加した変更を取り消す(=最新のコミットの状態に戻す)

$ git reset HEAD ファイル名(またはディレクトリ名)
「git reset HEAD .」とすると、全ファイルの変更が前回のコミットの状態に戻ります。
また、このコマンドのみではワークツリーの変更は元に戻らないので注意が必要です。
ワークツリーも元に戻したい場合は、このresetコマンドを実行した後、前述のcheckoutコマンドを実行しましょう。

▼直前のコミットをやり直す

$ git commit --amend
最新のステージの状態で最新のコミットをやり直します。
一点注意点があり、リモートリポジトリへ既にプッシュしてしまった変更は取り消さないようにしましょう。他の人の余計な混乱を招く可能性があります。
既にリモートへプッシュしてしまった後に変更したい場合は、新しいコミットを作成してプッシュし直しましょう。

▼リモートリポジトリの情報を表示

$ git remote
「git remote -v」と入力するとより詳細な情報を確認することができます。

▼リモートリポジトリのより詳細な情報を表示

$ git remote show リモート名
リモート名は「origin」などが入ります。

▼リモートの情報を変更

$ git remote rename 旧リモート名 新リモート名

▼リモートの情報を削除

$ git remote rm 旧リモート名 新リモート名
当たり前ですが、ロケールのリポジトリから指定したリモートリポジトリの情報が削除されるだけで、リモートリポジトリが削除されるわけではありません。

▼リモートの情報を変更・削除

$ git remote rename 旧リモート名 新リモート名

▼リモートから情報を取得

$ git fetch リモート名
リモート名は「origin」などとなります。
このコマンドでローカルリポジトリへリモートのブランチとコミットの情報が取得されますが、ワークツリーへは反映されないことに注意してください。
ワークツリーに取り込む場合は以下のコマンドを実行しましょう。

▼別ブランチの変更を現在のワークツリーへ反映する

$ git merge ブランチ名
マージ先のブランチはコマンド実行時にチェックアウトしているブランチとなります。
ブランチ名を「origin/main」のようにすることで、前述のfetchコマンドで取ってきた情報を現在のワークツリーへ反映することができます。
「origin」をつけずにブランチ名だけ(featureなど)を指定すると、そのローカルのブランチの内容をマージすることができます。
また、マージ先ブランチの最新コミット履歴にマージされた側のコミット履歴が追加され、マージ先ブランチの最新コミットが新たに作られ更新されます。(例:masterにfeatureを取り込んだ場合、masterの最新コミット履歴にfeatureの最新コミット履歴が追加され、masterの最新コミットはfeatureでコミットしたものとなる。)

▼リモートからデータを取得してマージ

$ git pull リモート名 ブランチ名
pullコマンドは、fecth → mergeの順番でコマンドを実行した場合と同じ挙動となります。
マージ先のブランチはコマンド実行時にチェックアウトしているブランチになる点に注意しましょう。

▼リモートからデータを取得してリベース

$ git pull --rebase リモート名 ブランチ名
rebaseで取り込むことで、マージコミットがコミット履歴に残らないようになります。 シンプルにローカルブランチを最新に更新したい時に使用しましょう。

▼ローカルのブランチ一覧を表示

$ git branch
「-a」オプションを付けることによって、リモートのブランチもすべて表示されます。

▼ローカルにブランチを新規作成

$ git branch ブランチ名

▼リモートブランチからローカルブランチを新規作成

$ git branch ブランチ名 リモートブランチ名
例としては「git branch feature origin/feature」のような感じです。

▼ブランチ名を変更

$ git branch -m 新ブランチ名
コマンド実行時にチェックアウトしているブランチの名前が変更されます。

▼ブランチを削除

$ git branch -d ブランチ名
masterにマージされていない変更が残っている場合は警告が出て削除はされません。 「-d」の部分を「-D」に変更することで、警告を無視して強制削除できます。

▼ブランチを切り替え

$ git checkout ブランチ名
「git checkout -b ブランチ名」のように「-b」オプションを付けることで、ブランチの作成と切り替えを同時に行うことができます。

▼リモートブランチからローカルブランチを作成して切り替え

$ git checkout -b 作成するローカルブランチ名 リモートブランチ名
「git checkout -b feature origin/feature」のような感じです。

▼ブランチの履歴(親コミット)を更新する

$ git rebase ブランチ名
コマンド実行時にチェックアウトしているブランチの履歴(親コミット)を更新します。
featureブランチで作業をしている途中に、最新のmasterブランチの内容を取り込みたい場合などで使用します。
もちろん、masterへfeatureを取り込むことの可能です。
一点、一度リモートへプッシュしたコミットが最新の状態ではrebaseコマンドは実行しないようにしましょう。
リモートリポジトリとのコミット履歴の整合性が合わず、プッシュできなくなります。

▼過去のコミットを修正する・まとめる

$ git rebase -i HEAD~数字
このコマンドは実行後のステップが他のコマンドより少し複雑ですが、こちらの記事がわかりやすくまとめられていました。

▼タグを作成する

$ git tag タグ名
コマンド実行時にチェックアウトしているブランチの最新コミットにタグ付けされます。

▼既存のコミットにタグを作成する

$ git tag タグ名 コミットID

▼注釈付きタグを作成する

$ git tag -a タグ名 -m "タグの説明"
こちらもコマンド実行時にチェックアウトしているブランチの最新コミットにタグ付けされます。

▼既存のコミットに注釈付きタグを作成する

$ git tag -a タグ名 -m "タグの説明" コミットID

▼タグの一覧を表示する

$ git tag
上記コマンドの後ろに「-l 文字列」とオブションを追加することで、指定した文字列で始まるタグのみを表示することができます。

▼タグの詳細を表示する

$ git show タグ名

▼ローカルの全タグの情報をリモートへ反映

$ git push origin --tag

▼ローカルの特定のタグの情報をリモートへ反映

$ git push origin タグ名

▼作業を一時退避する

$ git stash
ワークツリーとステージの変更が一時退避されます。
現在のブランチで変更をコミットしたくないが、別のブランチにチェックアウトしたい場合などに使用します。

▼一時退避した(stashした)変更の一覧を確認

$ git stash list

▼一時退避した(stashした)変更をワークツリーに復元

$ git stash apply
一番最後にstashした内容が復元されます。
また、このコマンドだけではステージに追加した内容は退避されないことに注意しましょう。
ステージにも復元したい場合は以下のコマンドを実行します。

▼一時退避した(stashした)変更をワークツリーとステージに復元

$ git stash apply --index

▼一時退避した(stashした)特定の変更を復元

$ git stash apply stash@{スタッシュ番号}
スタッシュ番号は「git stash list」コマンドで確認しましょう。

▼一時退避した(stashした)作業を削除する

$ git stash drop
dropの後に「stash@{スタッシュ番号}」をつけると特定の退避作業を、「clear」をつけるとすべての退避中作業が削除されます。

コマンドは他にもあると思いますが、以上です。

コンフリクトが起きた場合の対処法

いつまで経ってもコンフリクトが起きるとテンパるので、解消手順をまとめます。
  • 「git status」コマンドでコンフリクトが起きているファイルを特定する。(「both modified」と表示されているファイルがコンフリクトが起きているファイル)
  • 任意のテキストエディタで、コンフリクトが起きているファイルを開く。
  • 不要な行は削除して、最終的にしたい形にファイルを変更する。
  • 以下の行を削除する。
  • <<<<<<< HEAD
    =======
    >>>>>>> feature
  • ファイルを保存し、「git add」、「git commit」を実行する。
以上です。これで安心です。

mergeとrebaseの使い分け

mergeとrebaseをどのように使い分ければよいか迷うので、参考としてまとめます。
  • merge → リモートへプッシュした後に取り込む場合。
  • rebase → リモートへプッシュしておらずローカルの履歴を整理したい場合。

その他メモ

以下、その他個人的なメモです。
  • ブランチは飽くまで、最新のコミットがどれかを指し示すポインタである。
  • 「HEAD」はその時点でチェックアウトしているポインタ(ブランチ)を指し示すものである。(featureにチェックアウトしている場合は、featureを示すことになる)

最後に

以上、Gitのコマンドについて簡単でしたがまとめてみました。

何度も打っているはずのコマンドですが、多くのコマンドが頭の中に保存されず抜けていってしまいます笑。
こんなの知ってるよ!という内容だったかと思いますが、以上、どなたかの役にたてば幸いです!

それでは!