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.2.0 | ケースフォールディングは、setlocale() で設定されたロケールに依存しなくなりました。 ASCII のケースフォールディングのみが行われます。 ASCII でないバイト列は、バイト値として比較されます。 |
| 8.0.0 |
needle は、空文字列を受け入れるようになりました。
|
| 8.0.0 |
needle に数値を渡すことはサポートされなくなりました。
|
| 7.3.0 |
needle に数値を渡すことは非推奨になりました。
|
例1 stristr() の例
<?php
$email = 'USER@EXAMPLE.com';
echo stristr($email, 'e'), PHP_EOL; // outputs ER@EXAMPLE.com
echo stristr($email, 'e', true), PHP_EOL; // outputs US
?>
例2 文字列が見つかるかどうかをテストする
<?php
$string = 'Hello World!';
if (stristr($string, 'earth') === FALSE) {
echo '"earth" not found in string';
}
// 出力は "earth" not found in string となります
?>注意: この関数はバイナリデータに対応しています。