.gitignoreで無視フォルダの中の特定のファイルを除外「!(否定文)」を使う場合の注意点
2019/02/24
.gitignoreの設定で除外「!(否定文)」を使う場合の注意点
.gitignoreの基本的な設定方法
Gitでファイルを管理する場合、管理対象にするファイルと管理対象にしないファイルの設定を「.gitignore」ファイルにします。
「.gitignore」ファイルの記述の方法の基本形は以下の通りとなっています。
「.gitignore」ファイルは、複数のフォルダに設置することが可能。
下層に行くほど優先される(記述内容が上書きされる)。
コメント
"#"
で始まる行はコメントとなります。
1 |
# "#"で始まる行はコメント |
ファイルを指定する
.gitignoreファイルにファイルを指定すると、そのファイルは git管理の対象外となります。
1 2 3 4 5 6 7 8 |
# すべてのフォルダ内の「test.php」を無視する test.php # すべてのフォルダ内でマッチする「test/test.php」を無視する test/test.php # 「.gitignore」がおいてある直下の「/test/test.php」を無視する /test/test.php |
フォルダを指定する
.gitignoreファイルにフォルダを指定すると、そのフォルダは Git管理の対象外となります。
1 2 3 4 5 6 7 8 |
# すべてのフォルダ内の「test_folder」を無視する test_folder/ # すべてのフォルダ内でマッチする「test_folder/test_folder/」を無視する test_folder/test_folder/ # 「.gitignore」がおいてある直下の「test_folder/test_folder/」を無視する test_folder/test_folder/ |
管理対象外としてフォルダを指定すると、フォルダ内にあるフォルダも管理対象外となるため、そのフォルダ内のパスを指定してもそもそも管理対象外であるため正常に反映されません。
今回の記事のポイントは、このフォルダの指定の仕方になります。
正規表現を使って指定する
.gitignoreファイルに指定するファイルやフォルダは、正規表現を使用して複数のファイル、フォルダを指定することもできます。
1 2 3 4 5 |
# 「.gitignore」がおいてある直下の「/test/」フォルダ内のすべてのファイル、フォルダを無視する /test/* # 「.gitignore」がおいてある直下の「/test/」フォルダ内の拡張子が「css」のファイルを無視する /test/*.css |
「!」を使って無視対象の否定設定をする
無視対象のフォルダの中の特定のファイルを無視対象から外す場合は「!(否定文)」を使います。
1 2 |
/test/* !/test/test1.php |
上記は、「test」フォルダは無視対象にしますが、その中の「test1.php」は無視対象から外す(監視対象にする)という設定になります。
.gitignoreの具体的な設定方法・対象外のフォルダ内のフォルダの指定方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
vendor ├─test1 │ test11.php │ test12.php │ ├─test2 │ ├─test21 │ │ ├─test211 │ │ │ test2111.php │ │ │ test2112.php │ │ │ │ │ └─test212 │ │ test2121.php │ │ test2122.php │ │ │ └─test22 │ ├─test221 │ │ test2211.php │ │ test2212.php │ │ │ └─test222 │ test2221.php │ test2222.php │ └─test3 └─test31 ├─test311 │ test3111.php │ test3112.php │ └─test312 test3121.php test3122.php |
無視対象のフォルダの中のファイルを「!」を使って指定する
上記のような構成の中で、
/vendor/test1/test11.php
上記のファイルを無視対象(除外対象)から外したい場合は、下記のような記述になります。
1 2 3 4 |
/vendor/* !/vendor/test1/ /vendor/test1/* !/vendor/test1/test11.php |
下記の記述方法では正常に動作しません。
1 2 |
/vendor/* !/vendor/test1/test11.php |
先の基本的な「.gitignoreの基本的な設定方法」の「フォルダを指定する」で少し触れましたが、最初に「/vendor/*
」を記述していますので、「vendor」フォルダ内のすべてのファイル、フォルダが管理対象外(無視対象)となっています。
そのため、続けて「/vendor/test1/test11.php
」を指定しても「/vendor/test1/
」も無視の対象となっているため、無視の対象から除外することができません。
そのため、「!/vendor/test1/
」を追加することで、無視対象の「vendor」フォルダの中の「test1」だけは無視対象から除外(否定)する設定を行います。
さらに「/vendor/test1/*
」を追加して、改めて「/vendor/test1/
」フォルダ内のファイル、フォルダを無視対象にする設定を行います。
同様に
/vendor/test2/test21/test211/test2111.php
上記のファイルを無視対象(除外対象)から外したい場合は、下記のような記述になります。
1 2 3 4 5 6 7 8 |
/vendor/* !/vendor/test2/ vendor/test2/* !/vendor/test2/test21/ vendor/test2/test21/* !/vendor/test2/test21/test211/ vendor/test2/test21/test211/* !/vendor/test2/test21/test211/test2111.php |
無視対象にしたフォルダの中の特定のファイル、フォルダを無視対象から外す(無視設定を否定)する場合は、その途中のパスも無視対象から外す(無視設定を否定)する設定をしていく必要が出てきます。
無視対象から外す設定は、階層が深くなるとそれだけ記述が長くなり面倒になります。
無視対象のフォルダの中のフォルダが 1つしかない場合の対応方法
さらに厄介なのが、「test31」のように、経由するフォルダの中にフォルダが 1つしかない場合です。
下記のように記述してもうまく動作しません。
1 2 3 4 5 6 7 8 |
/vendor/* !/vendor/test3/ vendor/test3/* !/vendor/test3/test31/ vendor/test3/test31/* !/vendor/test3/test31/test311/ vendor/test3/test31/test311/* !/vendor/test3/test31/test311/test3111.php |
下記は分かりやすいように 3行目、4行目をコメントにしていますが、下記のように「test31」の指定部分を削除する必要があります。
1 2 3 4 5 6 7 8 |
/vendor/* !/vendor/test3/ #vendor/test3/* #!/vendor/test3/test31/ vendor/test3/test31/* !/vendor/test3/test31/test311/ vendor/test3/test31/test311/* !/vendor/test3/test31/test311/test3111.php |
.gitignoreの設定方法のあと
.gitignoreを設定すると、その内容を反映し、無視対象から外したファイル(gitの管理対象に加えたファイル)を、改めて「git add .」で追加して、コミットする必要があります。
ですが、Gitはコミットした情報をキャッシュとして管理していますので、.gitignoreを更新しただけではうまく管理対象に加えたファイルを処理してくれない場合があります。
そんな場合は、Gitのキャッシュを削除する対応が必要になりますが、それについては下記に記事を書いていますので、併せて参考にしてください。
.gitignoreを更新しても反映されないときは「git rm -r --cached .」でキャッシュを削除
Git関連の記事
Gitはフォルダ自体を管理対象にはできない。空のフォルダを設定する手順.gitignoreを更新しても反映されないときは「git rm -r --cached .」でキャッシュを削除
.gitignoreで無視フォルダの中の特定のファイルを除外「!(否定文)」を使う場合の注意点
Gitで「fatal: Authentication failed for 'https://example.com/git_repositories/example.git/'」のエラーが出た場合の対処方法の一つ
Gitで基本的なデプロイ(push、pullで本番公開)環境を作る手順解説
その他の「git」に関する記事一覧
GoogleAdwords
GoogleAdwords
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
本当に?GMO系ロリポップ・ヘテムルを無料で運用する方法があった!
ロリポップ、ヘテムルを株主優待を利用して実質無料で運営しよう!という解説記事です。株主優待で提供されるサービスの内容を解説し、無料になる仕組みを解説します。
-
Beautiful Soupを利用してPythonでスクレイピングを行う環境構築方法の解説
BeautifulSoupはPythonでスクレイピングを行う際に便利なツール。インストール方法も簡単。ただ、事前にpipのインストールが必要でその解説もしてます。
-
コピーコンテンツ対策.htaccessで直リンク禁止しリダイレクトで対応
不正なコピーコンテンツからの直リンクを拒否する.htaccessの設定方法。拒否するサイトを指定、許可するサイトを指定する方法、単純な拒否と画像の差し替えを解説。
-
Gitで基本的なデプロイ(push、pullで本番公開)環境を作る手順解説
開発進行中の環境、公開中の環境にGitを導入する。その基本的な手続きを解説。Gitの導入、ローカルリポジトリを作成。リモートリポジトリを利用し、本番環境にデプロイする手続きを解説。
-
サイト更新、引越時に.htaccessでリダイレクトする方法解説
サイト更新,引越しなどでサイトのURLが変わった場合のリダイレクトを.htaccessのRewriteEngineを使って処理する方法の解説です。
-
.htaccessのmod_expiresでブラウザキャッシュで高速化でSEO対策!
Page Speed Insightsの指摘事項のファイルのブラウザキャッシュの設定方法。解説もしてるけど、.htaccessにコピペするだけの簡単設置で効果抜群!SEOにも威力を発揮!
-
mod_pagespeedでWebサイトを超簡単高速化・Google謹製の最終兵器
Webサイトの表示スピード高速化の最終兵器、Google謹製mod_pagespeedの解説です。レンタルサーバではX-Serverでしか利用できませんが、ワンクリックで高速化します。
-
PythonでMySQLへの接続ライブラリMySQL-pythonの簡単インストール方法
PythonはMySQLに接続するライブラリは別途インストールが必要。なのでMySQL-pythonライブラリのインストール方法とサンプルスクリプトで動作検証までを解説。
-
WordPress、Webサイトの表示高速化!画像を軽くする基本的な考え方
画面表示の高速化には画像のファイル容量を小さくする方法があります。ツールを使わなくても小さくするための基本的な考え方を解説します。
-
X Serverへの引越しの注意点まとめ。ロリポップとの違いと対処方法 6事例
ロリポップからX Serverに引越し。ロリポップとX Serverの違いに注目することでX Serverの設定方法を明確にします。またX Serverならではの設定ポイントなども解説。