PHP 8.4.0 RC2 available for testing

grapheme_stripos

(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL intl >= 1.0.0)

grapheme_stripos大文字小文字を区別せず、文字列内で最初にあらわれる場所の (書記素単位の) 位置を見つける

説明

手続き型

grapheme_stripos(string $haystack, string $needle, int $offset = 0): int|false

大文字小文字を区別せず、文字列内で最初にあらわれる場所の (書記素単位の) 位置を見つけます。

パラメータ

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

参考

add a note

User Contributed Notes 1 note

up
0
Anonymous
6 years ago
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';}
To Top