(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)
fnmatch — ファイル名がパターンにマッチするか調べる
$pattern
, string $filename
, int $flags
= 0): bool
fnmatch()はfilename
で指定された文字列が
pattern
で指定されたシェルワイルドカードにマッチするかどうかチェックします。
pattern
シェルのワイルドカードパターン。
filename
調べたい文字列。この機能は特にファイル名のマッチに便利ですが、 通常の文字列に関しても使用できます。
一般的なユーザーにとって、シェルパターンやあるいは少なくとも
'?'
と'*'
によるワイルドカードのほうが
慣れていると思われます。そのため、
preg_match()
の代わりに fnmatch()
をフロントエンドの検索表現として使うことは、
プログラマではないユーザーにとってより便利でしょう。
flags
flags
の値は、以下のフラグを
論理 OR (|) 演算子
で連結した任意の組み合わせです。
フラグ |
説明 |
---|---|
FNM_NOESCAPE |
バックスラッシュのエスケープを無効にする。 |
FNM_PATHNAME |
文字列内のスラッシュは、指定したパターン内のスラッシュにのみマッチする。 |
FNM_PERIOD |
文字列の先頭のピリオドは、指定したパターン内のピリオドにマッチしなければならない。 |
FNM_CASEFOLD |
大文字小文字を区別しないマッチ。GNU 拡張の一部。 |
マッチした場合に true
、それ以外の場合に false
を返します。
例1 シェルのワイルドカードパターンによる色の名前のチェック
<?php
if (fnmatch("*gr[ae]y", $color)) {
echo "some form of gray ...";
}
?>
今のところ、この機能は POSIX に準拠していないシステムで利用できません (ただし、Windows では利用できます)。