As expected, grapheme_stripos() does return boolean FALSE if the needle is not found in the haystack.
Use strict type comparison to check for that condition, like:
if (FALSE === grapheme_stripos('a', 'b')) {print 'Needle not found';}
(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL intl >= 1.0.0)
grapheme_stripos — 大文字小文字を区別せず、文字列内で最初にあらわれる場所の (書記素単位の) 位置を見つける
手続き型
大文字小文字を区別せず、文字列内で最初にあらわれる場所の (書記素単位の) 位置を見つけます。
haystack
探す対象となる文字列。正しい形式の UTF-8 でなければなりません。
needle
探したい文字列。正しい形式の UTF-8 でなければなりません。
offset
オプションの offset
パラメータで、haystack
のどの位置 (バイト数や文字数ではなく、書記素単位) から探し始めるのかを指定します。
負の値を指定した場合は、文字列の末尾からのオフセットとみなします。
offset
の値にかかわらず、返される値は常に haystack
の先頭からの位置になります。
位置を表す整数値を返します。needle
が見つからない場合は
grapheme_stripos() は false
を返します。
バージョン | 説明 |
---|---|
7.1.0 |
負の offset をサポートするようになりました。
|
例1 grapheme_stripos() の例
<?php
$char_a_ring_nfd = "a\xCC\x8A"; // 'LATIN SMALL LETTER A WITH RING ABOVE' (U+00E5) normalization form "D"
$char_o_diaeresis_nfd = "o\xCC\x88"; // 'LATIN SMALL LETTER O WITH DIAERESIS' (U+00F6) normalization form "D"
$char_O_diaeresis_nfd = "O\xCC\x88"; // 'LATIN CAPITAL LETTER O WITH DIAERESIS' (U+00D6) normalization form "D"
print grapheme_stripos( $char_a_ring_nfd . $char_a_ring_nfd . $char_o_diaeresis_nfd, $char_O_diaeresis_nfd);
?>
上の例の出力は以下となります。
2