.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
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
.htaccessのmod_deflateでファイル圧縮送信で高速化でSEO対策!
Page Speed Insightsの指摘事項であるファイルの圧縮送信の対応方法。処理内容の解説もあるけど、.htaccessにコピペするだけの簡単設置で効果抜群!SEOにも威力を発揮!
-
Gitで基本的なデプロイ(push、pullで本番公開)環境を作る手順解説
開発進行中の環境、公開中の環境にGitを導入する。その基本的な手続きを解説。Gitの導入、ローカルリポジトリを作成。リモートリポジトリを利用し、本番環境にデプロイする手続きを解説。
-
エックスサーバーで独自SSLは永久無料で取り放題。利用方法と理由を解説!
エックスサーバーでは独自SSLが無料でいくつでも設置できるように!しかも、国、都道府県などの数項目の入力と数クリックだけという超簡単!SSL化しない理由がない!
-
Gitで「fatal: Authentication failed for ‘https://example.com/git_repositories/example.git/’」のエラーが出た場合の対処方法の一つ
Gitのリモートリポジトリにアクセスする際、Authentication failedのエラーが。しかし、ID、PASSが間違っているのではなく、リモートリポジトリのURLが間違っている場合もあるので再度確認を。
-
Webサイト公開時に重複コンテンツを排除する.htaccessのリダイレクトの設定のまとめ
サイトを公開する際にはURLの正規化は必須です。正規化とは何かを解説し、.htaccessに設定すべきリダイレクトの設定を具体的に説明します。
-
PythonでUTF-8など日本語(全角文字)を使う方法。コメントにも必要。
Pythonの標準では日本語(全角文字)を利用できないので、利用する際は文字コードを宣言する必要がある。「# coding: utf-8」の様に記述すればOK。
-
Selenium WebDriverでFirefoxをプライベートウィンドウ/Chromeをシークレットモードで起動する方法・言語はpython
Seleniumでは初期状態でブラウザを起動する Seleniumでブラウザ …
-
EストアのショップサーブのWordPressサービスにメリット無し
ショップサーブのオプションサービスのWordPressを使ってみましたがデータベースには直接触れず使えないサービスでした。
-
ブラウザのキャッシュを活用するの対策!広告バナーを消して表示を高速化
あなたのサイトが遅いのはバリューコマースのバナーではないですか?バリューコマースのバナーを外すだけでmod_deflateとmod_expiresを設定するより効果があります!
-
PythonでMySQLへの接続ライブラリMySQL-pythonの簡単インストール方法
PythonはMySQLに接続するライブラリは別途インストールが必要。なのでMySQL-pythonライブラリのインストール方法とサンプルスクリプトで動作検証までを解説。