git cloneでブランチを指定する方法

git cloneでブランチを指定する方法

公開: 更新:
CodeCampが提供するDX人材育成が可能なプログラミングやITが学べる公開講座

Gitでリモートリポジトリをクローンする際、デフォルトではmainやmasterなどのデフォルトブランチが取得されます。しかし、開発中の特定のブランチで作業を開始したい場合や、必要なブランチだけを効率的に取得したい場合は、ブランチを指定してクローンする方法が便利です。

この記事では、git cloneでブランチを指定する具体的なコマンドと、指定時の注意点について解説していきます。



git cloneでブランチを指定するコマンド

git cloneでブランチを指定するには、-bオプションを使用します。-bオプションはclone後にチェックアウトされるブランチ(またはタグ)を指定するためのオプションで、任意のブランチを指定してクローンできます。

-bオプション単体での基本指定に加えて、取得範囲を絞る補助オプションを併用できます。以下の3つの使い方があります。

  1. -bオプションで指定する
  2. --single-branchで単一ブランチのみ取得する
  3. --depthで履歴を限定して取得する

-bは基本のブランチ指定で、--single-branchや--depthは-bと組み合わせて取得範囲を制限する補助オプションです。

それでは各項目について、詳しく解説していきます。

-bオプションで指定する

-bオプションは、git cloneでブランチを指定する最も基本的な方法です。-bの後にブランチ名を指定することによって、clone完了後にそのブランチがチェックアウトされた状態になります。

git clone -b ブランチ名 リポジトリURL

たとえば、developブランチを指定してクローンする場合は以下のように記述します。

git clone -b develop https://github.com/example/repo.git

上記のコマンドを実行すると、リポジトリ全体がクローンされ、作業ディレクトリはdevelopブランチの状態になります。Git公式ドキュメントでは、-bオプションについて以下のように説明されています。

Point the newly created HEAD to <name> branch instead of the branch pointed to by the cloned repository's HEAD. --branch can also take tags and detaches the HEAD at that commit in the resulting repository.

出典:Git公式ドキュメント - git-clone

-b(--branchの短縮形)を使用した場合でも、リモートリポジトリの各ブランチのリモート追跡ブランチは通常のgit cloneと同様に作成されるため、clone後にgit switch mainなどで他のブランチに切り替えることも可能です。なお、-bにはタグ名も指定できます(詳細は後述のよくある質問を参照してください)。

--single-branchで単一ブランチのみ取得する

--single-branchオプションは、指定したブランチの情報だけを取得するオプションです。-bオプションと組み合わせることによって、不要なブランチのデータを取得せずにクローンできるため、リポジトリのサイズが大きい場合にクローン時間やディスク使用量を削減できます。

git clone -b ブランチ名 --single-branch リポジトリURL

たとえば、featureブランチだけを取得する場合は以下のように記述します。

git clone -b feature --single-branch https://github.com/example/repo.git

上記のコマンドでは、featureブランチの先端に至る履歴のみが取得されます。Git公式ドキュメントでは、--single-branchについて以下のように説明されています。

Clone only the history leading to the tip of a single branch, either specified by the --branch option or the primary branch remote's HEAD points at.

出典:Git公式ドキュメント - git-clone

このオプションを指定した場合、他のブランチのリモート追跡ブランチは作成されないため、git branch -aには指定したブランチ関連のもののみが表示されます。CI/CDパイプラインやビルド環境など、特定のブランチだけが必要な場面で有効です。


Python研修一覧はこちら

目的に合うPython研修を一覧形式から探したい方は、ぜひご利用ください。

Python研修を比較する

Java研修一覧はこちら

目的に合うJava研修を一覧形式から探したい方は、ぜひご利用ください。

Java研修を比較する

PHP研修一覧はこちら

目的に合うPHP研修を一覧形式から探したい方は、ぜひご利用ください。

PHP研修を比較する

新入社員研修

目的に合う新入社員研修を一覧形式から探したい方は、ぜひご利用ください。

新入社員研修を比較する

全ての研修からも探したい方はこちら

--depthで履歴を限定して取得する

--depthオプションは、コミット履歴の取得数を制限するオプションです。シャロークローン(浅いクローン)とも呼ばれ、指定した数だけの最新コミットを取得します。

-bオプションと組み合わせることによって、特定ブランチの最新状態だけを高速に取得できます。

git clone -b ブランチ名 --depth 1 リポジトリURL

たとえば、developブランチの最新コミットだけを取得する場合は以下のように記述します。

git clone -b develop --depth 1 https://github.com/example/repo.git

上記のコマンドでは、developブランチの最新1コミット分のみがクローンされます。なお、--depthを指定すると暗黙的に--single-branchも有効になるため、他のブランチのリモート追跡ブランチは作成されません。

コミット履歴が膨大なリポジトリでもクローン時間を大幅に短縮できますが、取得されていない過去の履歴は参照できません。指定ブランチの完全な履歴が必要になった場合はgit fetch --unshallowで取得し直すことが可能です。

全ブランチの情報を追加で取得したい場合は、後述のよくある質問で紹介しているフェッチ設定の変更手順を参照してください。

git cloneでブランチを指定する際の注意点

git cloneでブランチを指定する場合、オプションの指定ミスや存在しないブランチ名の入力によってエラーが発生することがあります。以下の2つの注意点を把握しておくことによって、トラブルを未然に防げます。

  1. 存在しないブランチ名を指定した場合の挙動
  2. clone後にブランチを確認する方法

特に、ブランチ名のタイプミスは初心者がつまずきやすいポイントです。clone後のブランチ確認を習慣にしておくと、意図したブランチで作業を開始できているかを素早く判断できます。

それでは各項目について、詳しく解説していきます。

存在しないブランチ名を指定した場合の挙動

-bオプションに存在しないブランチ名を指定した場合、git cloneはエラーを返してクローン自体が実行されません。エラーメッセージはGitのバージョンによって異なりますが、「Remote branch [ブランチ名] not found in upstream origin」のような内容が表示されます。

# 存在しないブランチを指定した場合
git clone -b nonexistent https://github.com/example/repo.git
# fatal: Remote branch nonexistent not found in upstream origin

上記のように、クローンはエラーで終了しますが、作業ディレクトリが途中まで作成された状態で残る場合があります。再度クローンする前に、残ったディレクトリを削除するか別名でクローンし直してください。

リモートのブランチ一覧はgit ls-remote --heads リポジトリURLで事前に確認できます。

clone後にブランチを確認する方法

git cloneでブランチを指定した後は、意図したブランチで作業ディレクトリが構成されているかを確認することが重要です。確認にはgit branch --show-currentコマンドを使用します。

# 現在のブランチを確認する
git branch --show-current

# 全ブランチ(リモート含む)を確認する
git branch -a

上記のコマンドでは、git branch --show-currentで現在チェックアウトされているブランチ名が表示されます。git branch -aを実行するとローカルブランチとリモート追跡ブランチの一覧が表示されるため、--single-branchを使用した場合に取得されたブランチの範囲も確認できます。


Python基礎・実践(Django)

企業・法人向けのPython研修では、基礎から応用まで体系的に学べます。

Python研修の詳細

DX社員研修

企業・法人向けのDX研修では、実務に繋がるリスキリングでITレベルを向上させます。

DX研修の詳細

Javaエンジニア育成研修

企業・法人向けのJavaエンジニア育成研修では、Javaの基礎から応用まで確実に習得できます。

Java研修の詳細

新卒・新入社員向け研修

企業・法人に新入社員・新卒社員に向けたプログラミング研修を提供しています。

新入社員研修の詳細

コードキャンプのIT研修を全て見る

git cloneのブランチ指定に関するよくある質問

git clone -bとgit clone後にgit switchする方法はどちらがよいですか?

通常のcloneを前提にすれば、最終的な作業ブランチの状態はほぼ同じです。git clone -bは最初から目的のブランチでチェックアウトされるため手順が少なくて済みます。

clone後に複数のブランチを確認してから選びたい場合は、通常のgit cloneの後にgit switchで切り替える方法が適しています。

方法 適した場面
git clone -b 作業ブランチが確定している
clone後にgit switch ブランチを確認してから選びたい

どちらの方法でもリポジトリの内容に差異はないため、作業フローに合わせて選択してください。

タグを指定してcloneできますか?

-bオプションはブランチだけではなく、タグ名を指定することもできます。タグとは、特定のコミットに付けられた目印のことで、リリースバージョンの管理によく使われます。

git clone -b v1.0.0 https://github.com/example/repo.git

上記のコマンドを実行すると、v1.0.0タグが指すコミットの状態でクローンされます。ただし、タグを指定した場合はdetached HEAD状態(特定のブランチに属さない状態)になるため、新しいコミットを作成する場合はgit switch -c 新しいブランチ名でブランチを作成してください。

--single-branchでcloneした後に他のブランチを追加できますか?

--single-branchでクローンした後でも、追加のブランチを取得することは可能です。リモートのフェッチ設定を変更してからgit fetchを実行することによって、必要なブランチを後から追加できます。

# フェッチ設定を全ブランチ対象に変更する
git remote set-branches origin '*'

# リモートの全ブランチ情報を取得する
git fetch origin

上記のコマンドでは、まずgit remote set-branchesでフェッチ対象を全ブランチに拡大し、git fetch originで情報を取得しています。取得後はgit switch ブランチ名で任意のブランチに切り替えられます。

※上記コンテンツの内容やソースコードはAIで確認・デバッグしておりますが、間違いやエラー、脆弱性などがある場合は、コメントよりご報告いただけますと幸いです。

ITやプログラミングに関するコラム


ITやプログラミングに関するニュース

ブログに戻る

コメントを残す

コメントは公開前に承認される必要があることにご注意ください。

企業・法人向けのIT・プログラミング・生成AI研修を探す、比較する - IT・プログラミングを知って学べるコネクトメディア CodeCampが提供するDX人材育成が可能なプログラミングやITが学べる公開講座 - IT・プログラミングを知って学べるコネクトメディア コードキャンプが提供する無料で学べるプログラミングスクール講座 - IT・プログラミングを知って学べるコネクトメディア コードキャンプDX人材育成研修 - IT・プログラミングを知って学べるコネクトメディア 配属3ヶ月で30%の生産性向上を実現するいよぎんコンピュータサービスの新人研修に迫る - IT・プログラミングを知って学べるコネクトメディア 金融業界の業務効率化を加速するニッセイアセットマネジメントの生成AI×GAS活用研修事例 - IT・プログラミングを知って学べるコネクトメディア 【製造業のDX人材育成事例】デジタル人材の即戦力化を実現する、日本ガイシ株式会社の異動者向オンボーディング研修 - ITやプログラミングを知って学べるコネクトメディア フューチャーアーキテクト株式会社が実現した新入社員向けIT研修プログラムでタスクフォース制度が主体的な学びと成長を生み出す - IT・プログラミングを知って学べるコネクトメディア コードキャンプDX人材育成研修 - IT・プログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/【IT新入社員研修】オンラインとオフラインの最適バランスを実現したFutureOneの導入事例 - IT・プログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/【新入社員研修】柔軟なハイブリッド型Java研修で実現した新卒20名の成長と成果|サークレイス株式会社 - ITやプログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/現場により近いところにデジタルを根付かせるDX基礎講座研修|株式会社ブリヂストン - ITやプログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/業務の効率化・DX推進に向けたIT人材育成への第一歩|株式会社カナエ - ITやプログラミングを知って学べるコネクトメディア 企業・法人向けのIT・プログラミング研修 - ITやプログラミングを知って学べるコネクトメディア

新着記事

対象者別で探す

子供(小学生・中学生・高校生)向け
プログラミング教室検索する

子供(小学生・中学生・高校生)がロボットやプログラミング言語を学ぶことができるオフラインからオンラインスクールを検索、比較することが可能です。

子供(小学生・中学生・高校生)
プログラミング教室検索する

ITやプログラムなどの
最新情報を検索する

日々、新しいITやプログラミング言語の情報が流れていきますが、特定の情報を時系列でニュースやコラムを確認することができます。

ITやプログラムなどの
最新情報を検索する