Gitコマンド一覧
初期設定
-
git: メインのGitコマンド。各種サブコマンドを実行するために使います。
-
config: Gitの設定を管理します。ユーザー名やメールアドレスの設定などを行います。
git config --global user.name "Your Name"
git config --global user.email "your.email@example.com" -
help: Gitコマンドのヘルプ情報を表示します。
git help commit -
bugreport: Gitのバグを報告するためのコマンドです。
-
Credential helpers: 認証情報を管理するためのヘルパーです。たとえば、パスワードをキャッシュしたり、キーリングに保存したりします。
リポジトリの作成
- init: 新しいGitリポジトリを作成します。
git init - clone: 既存のリポジトリをクローン(コピー)します。
git clone https://github.com/user/repo.git
基本操作
- add: ファイルをインデックスに追加します(次のコミットに含めるため)。
git add file.txt - status: 現在のリポジトリの状態を表示します。
git status - diff: ワーキングディレクトリとインデックス、または他のコミットとの違いを表示します。
git diff - commit: インデックスに追加された変更を新しいコミットとして保存します。
git commit -m "Commit message" - notes: コミットに対する注釈を管理します。
git notes add -m "This is a note" - restore: 作業ツリーのファイルを復元します。
git restore file.txt - reset: インデックスまたは作業ツリーの状態をリセットします。
git reset HEAD~1 - rm: リポジトリからファイルを削除します。
git rm file.txt - mv: ファイルをリネームまたは移動します。
git mv oldname.txt newname.txt
ブランチの操作とマージ
- branch: ブランチを作成、リスト、削除します。
git branch
git branch new-branch - checkout: ブランチを切り替えます。または特定のコミットをチェックアウトします。
git checkout new-branch - switch: ブランチを切り替えます(checkoutの代替コマンド)。
git switch new-branch - merge: ブランチをマージします。
git merge new-branch - mergetool: マージの競合を解決するためのツールを起動します。
git mergetool - log: コミットログを表示します。
git log - stash: 作業中の変更を一時的に保存します。
git stash - tag: 特定のコミットにタグを付けます。
git tag v1.0 - worktree: 複数の作業ディレクトリを管理します。
git worktree add ../path/to/new-worktree
リポジトリの更新
- fetch: リモートリポジトリから変更を取得しますが、ワーキングツリーには反映しません。
git fetch origin - pull: リモートリポジトリから変更を取得し、ワーキングツリーにマージします。
git pull origin main - push: ローカルの変更をリモートリポジトリに送信します。
git push origin main - remote: リモートリポジトリを管理します。
git remote add origin https://github.com/user/repo.git - submodule: サブモジュールを管理します。サブモジュールは、他のリポジトリを含むリポジトリのことです。
git submodule add https://github.com/user/submodule-repo.git
ログの確認と比較
-
show: オブジェクト(コミット、ツリー、タグなど)を表示します。
git show -
log: コミットログを表示します。
git log -
diff: 差分を表示します。
git diff -
difftool: 外部ツールを使って差分を表示します。
git difftool -
range-diff: 2つのコミット範囲の差分を表示します。
git range-diff -
shortlog: 簡潔なログを表示します(著者ごとにグループ化)。
git shortlog -
describe: コミットに対してもっとも近いタグを示します。
git describe
パッチ
-
apply: パッチを適用します。
git apply patch.diff -
cherry-pick: 特定のコミットを別のブランチに適用します。
git cherry-pick commit_hash -
rebase: ブランチのベースを変更します。
git rebase main -
revert: 既存のコミットを元に戻すための新しいコミットを作成します。
git revert commit_hash
デバック
-
bisect: バイナリ検索を使ってバグを特定します。
git bisect start -
blame: ファイルの各行が最後に変更されたコミットとその著者を表示します。
git blame file.txt -
grep: リポジトリ内のファイルからパターンを検索します。
git grep "search pattern"