説明
stristr
( string $haystack
, string $needle
[, bool $before_needle
= false
] ) : string|false
haystack
において
needle
が最初に見つかった位置を含めてそこから最後までを返します。
パラメータ
haystack
- 検索を行う文字列。
needle
- PHP 8.0.0 より前のバージョンでは、
needle
が文字列でない場合、 数値に変換され、文字の通常の値として扱われていました。 この振る舞いは PHP 7.3.0 以降では推奨されないので、 この機能を使用しないことを強く推奨します。 意図した動作に依存する場合、needle
を string に明示的にキャストするか、 明示的に chr() 関数を呼び出すべきでしょう。 before_needle
true
にすると、stristr() の返り値は、haystack
の中で最初にneedle
があらわれる箇所より前の部分となります (needle は含めません)。
needle
および haystack
は大文字小文字を区別せずに評価されます。
返り値
マッチした部分文字列を返します。needle
が見つからない場合は false
を返します。
変更履歴
バージョン | 説明 |
---|---|
8.0.0 | needle に数値を渡すことはサポートされなくなりました。
|
7.3.0 | needle に数値を渡すことは非推奨になりました。
|
例
例1 stristr() の例
<?php $email = 'USER@EXAMPLE.com'; echo stristr($email, 'e'); // 出力は ER@EXAMPLE.com となります echo stristr($email, 'e', true); // PHP 5.3.0 以降では、出力は US となります?>
例2 文字列が見つかるかどうかをテストする
<?php $string = 'Hello World!'; if(stristr($string, 'earth') === FALSE) { echo '"earth" not found in string'; }// 出力は "earth" not found in string となります?>
例3 文字列以外の needle の指定
<?php $string = 'APPLE'; echo stristr($string, 97); // 97 = 小文字の a// 出力は APPLE となります?>
注意
注意:
この関数はバイナリデータに対応しています。
参考
- strstr() - 文字列が最初に現れる位置を見つける
- strrchr() - 文字列中に文字が最後に現れる場所を取得する
- stripos() - 大文字小文字を区別せずに文字列が最初に現れる位置を探す
- strpbrk() - 文字列の中から任意の文字を探す
- preg_match() - 正規表現によるマッチングを行う