Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】stristr()関数の使い方

stristr関数の使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

stristr関数は、与えられた文字列の中から、指定した部分文字列を大文字と小文字を区別せずに検索し、最初に見つかった部分文字列から元の文字列の最後までを返す関数です。この関数は、主に特定のキーワードを含む部分を抽出したい場合に使用されます。

第一引数には検索対象となる元の文字列を、第二引数には検索したい部分文字列を指定します。もし部分文字列が見つかった場合、stristr関数はその部分文字列が見つかった位置から元の文字列の終わりまでの部分を返します。例えば、「Hello World」という文字列から「world」を検索すると、「World」が見つかり、「World」から最後までである「World」が返されます。大文字小文字を区別しないため、「world」でも「World」でも一致し、柔軟な検索が可能です。

第三引数before_needleはオプションで、trueを指定すると、見つかった部分文字列より前の部分を返します。この引数をtrueに設定し、「Hello World」から「World」を検索した場合、「Hello 」が返されます。

検索する部分文字列が見つからなかった場合は、falseを返します。stristr関数は、文字列の中から特定の情報を大文字小文字を気にせずに抽出したい場合に非常に役立ちます。似た機能を持つ関数にstrstrがありますが、こちらは大文字小文字を厳密に区別する点でstristr関数と異なります。

構文(syntax)

1<?php
2$mainString = "The quick brown fox jumps over the lazy dog.";
3$searchNeedle = "FOX"; // 大文字小文字を区別せずに検索される
4$result = stristr($mainString, $searchNeedle);
5echo $result;
6?>

引数(parameters)

string $haystack, string $needle, bool $before_needle = false

  • string $haystack: 検索対象となる文字列
  • string $needle: 検索する文字列
  • bool $before_needle = false: trueの場合、$needle より前の部分を返す

戻り値(return)

string|false

指定された部分文字列が元の文字列内に存在する場合、その部分文字列が出現する位置から文字列の最後までを返します。見つからなかった場合は false を返します。

サンプルコード

PHP mb_stristrで大文字小文字を区別しない文字列検索

1<?php
2
3/**
4 * マルチバイト文字列に対応した、大文字・小文字を区別しない文字列検索を実行します。
5 *
6 * stristr() 関数はシングルバイト文字セット向けに設計されており、
7 * 日本語のようなマルチバイト文字を含む文字列では予期しない結果を返す可能性があります。
8 * そのため、マルチバイト文字を扱う場合は mb_stristr() の使用が強く推奨されます。
9 *
10 * @param string $haystack 検索対象の文字列。
11 * @param string $needle 検索する文字列。
12 * @param bool $before_needle trueの場合、needleが見つかった場合、needleの前の部分(needleは含まない)を返します。
13 *                           falseの場合、needleが見つかった場合、needleから文字列の終わりまでを返します。
14 * @return string|false 検索結果の文字列、またはneedleが見つからなかった場合は false を返します。
15 */
16function findCaseInsensitiveMultibyteString(string $haystack, string $needle, bool $before_needle = false): string|false
17{
18    // mb_internal_encoding() で設定された現在の内部エンコーディングを使用するか、
19    // mb_stristrの第4引数で明示的にエンコーディングを指定できます。
20    // UTF-8環境では通常、明示的な指定は不要ですが、安定性のために設定しておくのが良い習慣です。
21    // 例: mb_stristr($haystack, $needle, $before_needle, 'UTF-8');
22    $result = mb_stristr($haystack, $needle, $before_needle);
23
24    if ($result === false) {
25        echo "【検索失敗】'{$needle}' は '{$haystack}' の中に見つかりませんでした。\n";
26    } else {
27        $output_type = $before_needle ? "前の部分" : "以降の部分";
28        echo "【検索成功】'{$needle}' は '{$haystack}' の中に見つかりました。返された文字列({$output_type}): '{$result}'\n";
29    }
30
31    return $result;
32}
33
34// PHPのマルチバイト関数が正しく動作するために、内部エンコーディングをUTF-8に設定します。
35// これはスクリプトの早い段階で行うのが良い習慣です。
36mb_internal_encoding("UTF-8");
37
38echo "--- mb_stristr を利用した文字列検索の例 ---\n\n";
39
40// 例1: 大文字・小文字を区別しない通常の検索
41$text1 = "PHPはパワフルな言語です。";
42$term1 = "php"; // 小文字で検索しても見つかる
43findCaseInsensitiveMultibyteString($text1, $term1);
44// 期待される出力: 【検索成功】'php' は 'PHPはパワフルな言語です。' の中に見つかりました。返された文字列(以降の部分): 'PHPはパワフルな言語です。'
45
46// 例2: 日本語のマルチバイト文字列を含む検索
47$text2 = "こんにちは世界、PHPへようこそ。";
48$term2 = "ようこそ";
49findCaseInsensitiveMultibyteString($text2, $term2);
50// 期待される出力: 【検索成功】'ようこそ' は 'こんにちは世界、PHPへようこそ。' の中に見つかりました。返された文字列(以降の部分): 'ようこそ。'
51
52// 例3: $before_needle を true に設定
53$text3 = "これはサンプルテキストです。";
54$term3 = "サンプル";
55findCaseInsensitiveMultibyteString($text3, $term3, true);
56// 期待される出力: 【検索成功】'サンプル' は 'これはサンプルテキストです。' の中に見つかりました。返された文字列(前の部分): 'これは'
57
58// 例4: 検索文字列が見つからない場合
59$text4 = "リンゴとバナナがあります。";
60$term4 = "みかん";
61findCaseInsensitiveMultibyteString($text4, $term4);
62// 期待される出力: 【検索失敗】'みかん' は 'リンゴとバナナがあります。' の中に見つかりませんでした。
63
64// 例5: 大文字・小文字とマルチバイト文字の組み合わせ
65$text5 = "MySQL データベースを操作します。";
66$term5 = "mysql";
67findCaseInsensitiveMultibyteString($text5, $term5);
68// 期待される出力: 【検索成功】'mysql' は 'MySQL データベースを操作します。' の中に見つかりました。返された文字列(以降の部分): 'MySQL データベースを操作します。'
69
70?>

PHP 8のstristr関数は、指定した文字列の中から別の文字列を大文字・小文字を区別せずに検索する機能を提供します。しかし、この関数はシングルバイト文字セット向けに設計されており、日本語のようなマルチバイト文字を含む文字列では正確な結果を得られない可能性があります。そのため、マルチバイト文字を扱う際には、同等の機能を持つmb_stristr関数の使用が強く推奨されます。

mb_stristr関数は、$haystackという検索対象の文字列から、$needleという検索したい文字列を、大文字・小文字を区別せずに探します。$before_needle引数がfalse(デフォルト)の場合、$needleが見つかった位置から$haystackの最後までを返します。trueに設定すると、$needleが見つかるまでの$haystackの前の部分を返します。検索する文字列が見つからない場合はfalseを返します。サンプルコードでは、このmb_stristr関数を使って、PHPや日本語を含む様々な文字列から目的のテキストを検索し、その結果を表示しています。mb_internal_encoding関数で内部エンコーディングを適切に設定することで、マルチバイト文字の処理が正しく行われます。

日本語などのマルチバイト文字を扱う際は、標準のstristr関数ではなく、マルチバイト文字列に対応したmb_stristr関数を必ず使用してください。これにより、文字化けや予期せぬ検索結果の不一致を防ぐことができます。mb_stristrを正しく機能させるためには、スクリプトの早い段階でmb_internal_encoding("UTF-8")のように内部エンコーディングを設定するか、関数の引数で明示的にエンコーディングを指定することが重要です。検索が失敗した場合、mb_stristrはfalseを返しますので、結果を判定する際には=== falseのような厳密な比較演算子を使って、データ型まで含めて確認するようにしましょう。引数の$before_needleは、検索文字列の手前を切り出すか、以降を切り出すかを制御するため、目的によって使い分けてください。

PHP stristr 関数で大文字小文字を区別せずに文字列を検索する

1<?php
2
3/**
4 * stristr 関数の使用例を示します。
5 * stristr は、大文字小文字を区別せずに文字列を検索し、
6 * 見つかった場合はその部分から最後まで(またはそれより前)の文字列を返します。
7 */
8
9// 検索対象となる長い文字列
10$haystack = "Hello PHP Developers! We are learning string functions in PHP 8.";
11
12// 1. 基本的な使い方: 検索文字列が見つかった部分から最後までを返す(大文字小文字を区別しない)
13// "php" は "PHP" とマッチします。
14$needle1 = "php";
15$result1 = stristr($haystack, $needle1);
16if ($result1 !== false) {
17    echo "例1: '" . $needle1 . "' が見つかりました。結果: '" . $result1 . "'\n";
18} else {
19    echo "例1: '" . $needle1 . "' は見つかりませんでした。\n";
20}
21// 期待される出力: 'php' が見つかりました。結果: 'PHP Developers! We are learning string functions in PHP 8.'
22
23// 2. 検索文字列が見つからなかった場合
24$needle2 = "python";
25$result2 = stristr($haystack, $needle2);
26if ($result2 !== false) {
27    echo "例2: '" . $needle2 . "' が見つかりました。結果: '" . $result2 . "'\n";
28} else {
29    echo "例2: '" . $needle2 . "' は見つかりませんでした。\n";
30}
31// 期待される出力: 'python' は見つかりませんでした。
32
33// 3. 第三引数 $before_needle を true に設定: 検索文字列が見つかるまでの部分を返す
34// "Developers" が見つかるまでの部分が返されます。
35$needle3 = "Developers";
36$result3 = stristr($haystack, $needle3, true);
37if ($result3 !== false) {
38    echo "例3: '" . $needle3 . "' の前部分。結果: '" . $result3 . "'\n";
39} else {
40    echo "例3: '" . $needle3 . "' は見つかりませんでした。\n";
41}
42// 期待される出力: 'Developers' の前部分。結果: 'Hello PHP '
43
44// 4. 第三引数 $before_needle を false に設定 (デフォルト): 検索文字列が見つかった部分から最後までを返す
45// これは例1と同じ挙動を示しますが、明示的に false を指定しています。
46$needle4 = "functions";
47$result4 = stristr($haystack, $needle4, false);
48if ($result4 !== false) {
49    echo "例4: '" . $needle4 . "' が見つかりました。結果: '" . $result4 . "'\n";
50} else {
51    echo "例4: '" . $needle4 . "' は見つかりませんでした。\n";
52}
53// 期待される出力: 'functions' が見つかりました。結果: 'functions in PHP 8.'
54
55?>

PHPのstristr関数は、ある文字列($haystack)の中から、指定した別の文字列($needle)を大文字小文字を区別せずに検索する際に利用されます。この関数は、$needleが見つかった場合、その文字列が見つかった位置から$haystackの最後までを含む部分文字列を返します。もし$needleが見つからなかった場合は、falseを返します。

第三引数$before_needletrueを設定すると、$needleが見つかった際に、その$needleが見つかるまでの$haystackの前部分を返します。この引数はデフォルトでfalseが設定されており、その場合は$needleが見つかった位置から最後までを返します。

サンプルコードでは、まず「php」を大文字小文字を無視して検索し、「PHP Developers!...」という部分文字列を取得しています。次に「python」のような見つからない文字列を検索すると、falseが返されるため、その旨が示されます。さらに、「Developers」を検索する際に$before_needletrueに設定することで、「Hello PHP 」という前部分の文字列が取得できることを示しています。最後に、$before_needleを明示的にfalseに設定した場合の挙動も確認でき、「functions in PHP 8.」が返される様子が理解できます。

stristr関数は、文字列の大文字小文字を区別せずに検索する点が特徴です。目的の文字列が見つからない場合、戻り値はブール値のfalseとなります。このfalseは空の文字列とは異なるため、結果をチェックする際は!== falseのように厳密な等価演算子を使うことで、意図しないバグを防ぐことができます。第三引数をtrueに設定すると、検索文字列が見つかる「前」の部分が返され、デフォルトのfalseでは見つかった部分から「後」の文字列が返されます。この違いを理解して使い分けましょう。PHP 8の環境では、戻り値の型にstring|falseと明記されているため、型を意識した安全なコーディングを心がけることが重要です。

PHP stristr 関数で部分文字列を検索する

1<?php
2
3/**
4 * stristr関数の使用例を示すスクリプト。
5 * この関数は、大文字・小文字を区別せずに文字列内で特定の文字列を検索します。
6 * システムエンジニアを目指す初心者向けに、基本的な使い方を網羅しています。
7 */
8
9// 例1: 基本的な使い方 - 検索文字列が見つかった位置から元の文字列の最後までを返します。
10$mainString1 = "Hello World, how are you?";
11$searchString1 = "world"; // 大文字・小文字を区別しないため "World" とマッチします
12$result1 = stristr($mainString1, $searchString1);
13
14echo "--- 例1: 基本的な検索 ---\n";
15echo "元の文字列: '" . $mainString1 . "'\n";
16echo "検索文字列: '" . $searchString1 . "'\n";
17// stristrは見つからない場合falseを返すため、条件分岐で表示を調整します
18echo "結果: '" . ($result1 !== false ? $result1 : "見つかりませんでした") . "'\n\n";
19// 期待される出力: 'World, how are you?'
20
21// 例2: 第3引数をtrueに設定 - 検索文字列が見つかった位置より前の部分を返します。
22$mainString2 = "This is a simple example for stristr.";
23$searchString2 = "example";
24$result2 = stristr($mainString2, $searchString2, true);
25
26echo "--- 例2: 検索文字列より前を返す ---\n";
27echo "元の文字列: '" . $mainString2 . "'\n";
28echo "検索文字列: '" . $searchString2 . "'\n";
29echo "結果: '" . ($result2 !== false ? $result2 : "見つかりませんでした") . "'\n\n";
30// 期待される出力: 'This is a simple '
31
32// 例3: 検索文字列が大文字・小文字に関わらず一致することを確認。
33$mainString3 = "PHP is a popular scripting language.";
34$searchString3 = "php"; // 元の文字列では 'PHP' となっていますが、大文字・小文字を区別しません
35$result3 = stristr($mainString3, $searchString3);
36
37echo "--- 例3: 大文字・小文字の区別なし ---\n";
38echo "元の文字列: '" . $mainString3 . "'\n";
39echo "検索文字列: '" . $searchString3 . "'\n";
40echo "結果: '" . ($result3 !== false ? $result3 : "見つかりませんでした") . "'\n\n";
41// 期待される出力: 'PHP is a popular scripting language.'
42
43// 例4: 検索文字列が見つからない場合 - false が返されます。
44$mainString4 = "Learning PHP is fun.";
45$searchString4 = "Python"; // 元の文字列には存在しない文字列
46$result4 = stristr($mainString4, $searchString4);
47
48echo "--- 例4: 検索文字列が見つからない場合 ---\n";
49echo "元の文字列: '" . $mainString4 . "'\n";
50echo "検索文字列: '" . $searchString4 . "'\n";
51echo "結果: " . ($result4 === false ? "見つかりませんでした (falseが返されました)" : "'" . $result4 . "'") . "\n\n";
52// 期待される出力: '見つかりませんでした (falseが返されました)'
53
54?>

PHPのstristr関数は、大文字・小文字を区別せずに、ある文字列の中から特定の文字列を検索するために使用されます。この関数は、システムエンジニアを目指す上で文字列処理の基本として知っておくと役立ちます。

引数としては、まず検索対象となる元の文字列を$haystackに、次に検索したい文字列を$needleに指定します。三番目の引数$before_needleはオプションで、trueを指定すると検索文字列が見つかった位置より前の部分を返し、デフォルト値のfalseでは見つかった位置から元の文字列の最後までを返します。

例えば、「Hello World」という文字列から「world」を検索する場合、大文字・小文字を区別しないため「World」とマッチし、通常は「World, how are you?」のように検索された部分から後ろの文字列が返されます。もし$before_needletrueに設定し「This is a simple example」から「example」を検索すると、「This is a simple 」のように検索文字列の前の部分が返されます。

検索文字列が元の文字列内に見つからない場合、この関数はfalseを返します。そのため、関数の戻り値がfalseでないかを確認することで、検索が成功したかどうかを判断し、その後の処理を適切に行うことができます。これは、プログラムが予期せぬ動作をしないようにするための重要なポイントです。

stristr関数は、検索時に大文字・小文字を区別しない点が特徴です。例えば「world」で検索しても「World」と一致しますので、大文字・小文字を気にせず検索したい場合に便利です。最も重要な注意点は、検索文字列が見つからない場合にPHPのfalseが返されることです。そのため、結果を利用する際は、必ず!== falseのように厳密な比較演算子を使ってfalseかどうかを確認し、適切な処理を行うようにしてください。デフォルトでは、検索文字列が見つかった位置から元の文字列の最後までを返しますが、第3引数にtrueを指定すると、検索文字列より前の部分だけを取得できます。この関数はあくまで文字列の部分検索であり、より柔軟なパターン検索には正規表現関数(preg_matchなど)の利用も検討すると良いでしょう。

PHP stristr関数で大文字小文字を区別せず検索する

1<?php
2
3/**
4 * stristr関数の使用例
5 * stristrは、大文字小文字を区別せずに文字列の中から指定した部分文字列を探し、
6 * その部分文字列が見つかった位置から残りの文字列、またはそれ以前の文字列を返します。
7 * 見つからなかった場合はfalseを返します。
8 */
9
10// 検索対象の文字列
11$text = "Hello World, PHP is awesome!";
12$search_text_found = "php"; // 大文字小文字を区別しないため "PHP" と一致する
13$search_text_before = "World";
14$search_text_not_found = "Java";
15
16echo "元の文字列: \"{$text}\"\n\n";
17
18// 例1: 大文字小文字を区別せず、最初に見つかった部分文字列から最後までを取得 (デフォルト動作)
19// "PHP" が "php" と一致し、その位置から後ろの文字列が返されます。
20$result1 = stristr($text, $search_text_found);
21if ($result1 !== false) {
22    echo "例1: '{$search_text_found}' を検索 (デフォルト動作) -> 結果: \"{$result1}\"\n";
23} else {
24    echo "例1: '{$search_text_found}' が見つかりませんでした。\n";
25}
26
27// 例2: 大文字小文字を区別せず、最初に見つかった部分文字列より前の部分を取得
28// "World" が見つかった場合、その前の部分 "Hello " が返されます。
29$result2 = stristr($text, $search_text_before, true);
30if ($result2 !== false) {
31    echo "例2: '{$search_text_before}' を検索 (前の部分) -> 結果: \"{$result2}\"\n";
32} else {
33    echo "例2: '{$search_text_before}' が見つかりませんでした。\n";
34}
35
36// 例3: 指定した部分文字列が見つからない場合
37// "Java" は元の文字列に含まれないため、falseが返されます。
38$result3 = stristr($text, $search_text_not_found);
39if ($result3 !== false) {
40    echo "例3: '{$search_text_not_found}' を検索 -> 結果: \"{$result3}\"\n";
41} else {
42    echo "例3: '{$search_text_not_found}' が見つかりませんでした。\n";
43}
44
45?>

stristr関数は、PHPにおいて文字列の中から特定の部分文字列を、大文字小文字を区別せずに検索する際に使用されます。この関数は、検索対象の文字列を$haystack、探したい部分文字列を$needleとして指定します。

基本的な動作として、$needleが見つかった場合、その部分文字列が見つかった位置から$haystackの最後までを新しい文字列として返します。もし、3つ目の引数$before_needletrueを指定すると、$needleが見つかった位置より前の部分の文字列を返します。$needleが見つからなかった場合は、falseを返します。

サンプルコードの例1では、"Hello World, PHP is awesome!"という文字列から"php"を検索し、大文字小文字を無視して"PHP"と一致するため、その位置から後ろの文字列"PHP is awesome!"が返されます。例2では、"World"より前の部分を返すように指定しているため、"Hello "が結果として得られます。例3のように、指定した"Java"が見つからない場合はfalseが返され、「見つかりませんでした」と表示されます。このように、stristr関数は文字列から必要な情報を柔軟に抽出するのに役立つ関数です。

stristr関数は、大文字小文字を区別せずに文字列を検索します。特に注意すべき点は、検索対象が見つからなかった場合にfalseが戻り値となることです。戻り値が空文字列""の場合とfalseの場合を区別するため、必ずif ($result !== false)のように厳密な比較で確認するようにしてください。これにより、予期せぬエラーを防ぎ、コードを安全に利用できます。また、第三引数にtrueを指定すると、見つかった部分文字列より前の部分が返されます。デフォルトは、見つかった部分文字列を含め、それ以降の部分を返す動作です。この関数の「i」は"insensitive"を意味し、大文字小文字を区別しないという特性を覚えておきましょう。

関連コンテンツ

関連プログラミング言語