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

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

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

作成日: 更新日:

基本的な使い方

explode関数は、指定された区切り文字(デリミタ)を用いて、対象の文字列を複数の部分文字列に分割し、それらを要素とする配列を生成する関数です。この関数は、例えばカンマ区切りのデータやスペース区切りの単語など、特定の規則で連結された文字列を個々の要素として扱いたい場合に非常に役立ちます。

利用する際には、まず第一引数に区切り文字となる文字列を指定します。次に第二引数には分割したい元の文字列を指定します。これにより、元の文字列の中から区切り文字が見つかるたびに文字列が分割され、分割された各部分が配列の要素として格納されます。結果として、分割された文字列の配列が返されます。

オプションとして、第三引数にlimit(リミット)という整数値を指定できます。limitを正の数で指定すると、返される配列の要素数が最大でその値に制限されます。例えばlimit2を指定すると、文字列は最初の1回だけ分割され、最大で2つの要素を持つ配列が返されます。負の数を指定すると、末尾からlimitの絶対値分の要素が除外されます。0を指定した場合は、空の配列が返されます。

注意点として、区切り文字に空文字列("")を指定した場合、PHP 8.0.0以降ではValueErrorが発生します。また、分割対象の文字列が空であり、区切り文字が空文字列でない場合は、空文字列を唯一の要素とする配列が返されます。この関数を使うことで、ログファイルからの情報抽出や、ユーザー入力のパースなど、様々な場面で文字列データを効率的に処理することが可能です。

構文(syntax)

1<?php
2explode(string $separator, string $string, int $limit = PHP_INT_MAX): array
3?>

引数(parameters)

string $separator, string $string, int $limit = PHP_INT_MAX

  • string $separator: 文字列を分割する際の区切り文字を指定します。
  • string $string: 分割したい対象の文字列を指定します。
  • int $limit = PHP_INT_MAX: 分割する要素の最大数を指定します。指定しない場合、PHP_INT_MAX(PHPで表現できる最大の整数)が使用され、制限はありません。

戻り値(return)

array|false

explode関数は、指定された区切り文字で文字列を分割し、その結果を配列として返します。区切り文字が見つからなかった場合や、空文字列を渡した場合などはfalseを返します。

サンプルコード

PHP explode 関数の使い方:文字列を分割する

1<?php
2
3/**
4 * PHPのexplode関数は、文字列を指定した区切り文字で分割し、
5 * 分割された部分文字列の配列を返すために使用されます。
6 * システムエンジニアを目指す初心者の方にも理解しやすいよう、
7 * 基本的な使い方と、limit引数の利用例を示します。
8 */
9
10// 1. 最も基本的な使い方: カンマ (,) で文字列を分割する例
11// explode(区切り文字, 分割対象の文字列)
12$string1 = "Apple,Banana,Orange";
13$fruits = explode(",", $string1);
14
15echo "--- 基本的な分割 (カンマ区切り) ---" . PHP_EOL;
16echo "元の文字列: '{$string1}'" . PHP_EOL;
17echo "分割結果 (配列): " . PHP_EOL;
18print_r($fruits);
19// この例では、"Apple", "Banana", "Orange" という3つの要素を持つ配列が生成されます。
20
21echo PHP_EOL; // 出力を区切るための改行
22
23// 2. スペースで文字列を分割する例
24// 空白文字 (" ") を区切り文字として指定します。
25$string2 = "Hello World PHP Program";
26$words = explode(" ", $string2);
27
28echo "--- スペースでの分割 ---" . PHP_EOL;
29echo "元の文字列: '{$string2}'" . PHP_EOL;
30echo "分割結果 (配列): " . PHP_EOL;
31print_r($words);
32// この例では、"Hello", "World", "PHP", "Program" という4つの要素を持つ配列が生成されます。
33
34echo PHP_EOL; // 出力を区切るための改行
35
36// 3. limit引数を使った分割: 最大分割数を指定する例
37// explode(区切り文字, 分割対象の文字列, limit)
38// limitが正の数の場合、最大でその数だけ要素が作成されます。
39// 最後の要素には、区切り文字以降の残りの文字列全体が含まれます。
40$string3 = "one:two:three:four:five";
41$limitedParts = explode(":", $string3, 3); // 最大3つの要素に分割
42
43echo "--- limit引数 (最大分割数) の利用 ---" . PHP_EOL;
44echo "元の文字列: '{$string3}'" . PHP_EOL;
45echo "limit = 3 で分割した場合: " . PHP_EOL;
46print_r($limitedParts);
47// この例では、最初の2つの区切り文字で分割され、
48// "one", "two", "three:four:five" という3つの要素を持つ配列が生成されます。
49
50?>

PHPのexplode関数は、指定した区切り文字に基づいて一つの文字列を複数の部分文字列に分割し、その結果を配列として返す機能を提供します。この関数は、ログファイルから特定の情報を抽出したり、CSVデータを行ごとに処理したりするなど、文字列から構造化されたデータを取り出す際に非常に役立ちます。

この関数は主に二つの引数を必要とします。一つ目の$separatorには、文字列を分割するための区切り文字を指定します。二つ目の$stringには、分割したい元の文字列そのものを指定します。例えば、「Apple,Banana,Orange」という文字列をカンマ「,」で分割すると、「Apple」「Banana」「Orange」という三つの要素を持つ配列が生成されます。同様に、スペース「 」を区切り文字として利用することで、「Hello World PHP」のような文字列を単語ごとに分割することも可能です。

さらに、オプションとして三つ目の引数$limitを指定できます。この引数は、生成される配列の最大要素数を制御します。$limitに正の整数を指定すると、文字列は指定された回数だけ分割され、最後の要素には区切り文字以降の残りの文字列全体がそのまま含まれます。例えば、「one:two:three:four」という文字列をコロン「:」で分割し、$limitを3と設定した場合、「one」「two」「three:four」という三つの要素からなる配列が得られます。

explode関数は、文字列の分割に成功すると、分割された部分文字列を含む配列を返します。しかし、何らかの理由で処理が失敗した場合にはfalseを返します。この関数を理解し活用することで、システム開発における文字列データの加工や解析作業を効率的に行うことが可能になります。

explode関数は、指定した区切り文字で文字列を分割し、結果を配列として返します。最も注意すべき点は、区切り文字に空の文字列("")を指定すると、戻り値がfalseとなることです。そのため、関数が正常に実行されたかを確認する習慣をつけましょう。また、分割対象の文字列内に区切り文字が見つからない場合でもエラーとはならず、元の文字列全体が唯一の要素として含まれる配列が返されます。サンプルコードにあるlimit引数を正の数で指定すると、その数だけ要素が作成され、最後の要素には残りの文字列全体が含まれる形で分割されます。

PHP explode 区切り文字がない場合の挙動

1<?php
2
3/**
4 * PHPの explode() 関数について、「区切り文字がない」場合の動作を示すサンプルコードです。
5 * システムエンジニアを目指す初心者の方にも理解しやすいよう、具体的な例を用いています。
6 */
7
8// ケース1: 分割対象の文字列中に区切り文字が存在しない場合
9// explode() 関数は、指定された区切り文字が文字列中に見つからない場合、
10// 元の文字列全体を1つの要素として含む配列を返します。
11$stringDataCase1 = "HelloWorld";
12$separatorCase1 = ","; // この区切り文字は文字列中に存在しません
13$resultCase1 = explode($separatorCase1, $stringDataCase1);
14
15echo "--- ケース1: 文字列中に区切り文字が存在しない場合 ---" . PHP_EOL;
16echo "元の文字列: '" . $stringDataCase1 . "'" . PHP_EOL;
17echo "指定した区切り文字: '" . $separatorCase1 . "'" . PHP_EOL;
18echo "結果の型と値:" . PHP_EOL;
19var_dump($resultCase1);
20echo PHP_EOL;
21
22// ケース2: 区切り文字として空文字列 ('') を指定した場合
23// PHP の explode() 関数は、区切り文字に空文字列を指定すると false を返します。
24// これはエラーケースとして扱われ、予期せぬ動作を防ぐための仕様です。
25$stringDataCase2 = "PHP_Expert";
26$separatorCase2 = ""; // 空文字列を区切り文字として指定
27
28echo "--- ケース2: 区切り文字が空文字列の場合 ---" . PHP_EOL;
29echo "元の文字列: '" . $stringDataCase2 . "'" . PHP_EOL;
30echo "指定した区切り文字: '" . $separatorCase2 . "' (空文字列)" . PHP_EOL;
31
32$resultCase2 = explode($separatorCase2, $stringDataCase2);
33
34if ($resultCase2 === false) {
35    echo "結果: false" . PHP_EOL;
36    echo "補足: explode() は区切り文字に空文字列を指定すると false を返します。" . PHP_EOL;
37} else {
38    echo "結果の型と値:" . PHP_EOL;
39    var_dump($resultCase2);
40}
41echo PHP_EOL;
42
43// 参考: 通常の explode() の動作(区切り文字が存在する場合)
44// 参考として、区切り文字が文字列中に存在する一般的なケースも示します。
45$stringDataNormal = "apple,orange,banana";
46$separatorNormal = ",";
47$resultNormal = explode($separatorNormal, $stringDataNormal);
48
49echo "--- 参考: 通常の explode() の動作 ---" . PHP_EOL;
50echo "元の文字列: '" . $stringDataNormal . "'" . PHP_EOL;
51echo "指定した区切り文字: '" . $separatorNormal . "'" . PHP_EOL;
52echo "結果の型と値:" . PHP_EOL;
53var_dump($resultNormal);
54
55?>

PHPのexplode()関数は、指定した区切り文字(セパレータ)に基づいて文字列を分割し、その結果を配列として返す関数です。引数には、区切り文字、分割対象の文字列、そしてオプションで分割数の上限値を指定します。戻り値は通常、分割された文字列の配列ですが、特定の条件下ではfalseを返します。

サンプルコードのケース1では、分割対象の文字列「HelloWorld」内に指定した区切り文字「,」が存在しません。このような場合、explode()関数は元の文字列全体を1つの要素として含む配列、すなわち['HelloWorld']を返します。これは、区切り文字が見つからないときでも元の情報を失わないための挙動です。

ケース2では、区切り文字として空文字列 ('') を指定しています。PHPのexplode()関数は、区切り文字に空文字列が指定された場合、処理を続行せずにfalseを返します。これは、空文字列による分割が意味を持たず、予期せぬ結果を引き起こす可能性があるため、エラーケースとして扱われる仕様です。

参考として示されている通常の動作では、文字列「apple,orange,banana」が区切り文字「,」によって「apple」「orange」「banana」の3つの要素に分割され、['apple', 'orange', 'banana']という配列が正しく生成されます。これらの特殊な挙動を理解しておくことは、文字列処理を含むプログラムを開発する上で非常に重要です。

PHPのexplode関数を使用する際、区切り文字が分割対象の文字列中に存在しない場合でも、エラーとはならず元の文字列全体を1つの要素とする配列が返されます。これは、区切り文字が見つからないからといって結果がfalseになるわけではないため、混同しないよう注意が必要です。また、区切り文字に空文字列 ('') を指定すると、関数は例外的な動作としてfalseを返します。そのため、explode関数の戻り値を使用する際は、結果がfalseでないか厳密な比較演算子 (===) を用いて常に確認することが、プログラムを安全に動作させるための重要なポイントとなります。

PHP explodeで文字列を複数分割する

1<?php
2
3/**
4 * 文字列を特定の区切り文字で複数の部分に分割するPHPのexplode関数の使用例。
5 *
6 * `explode`関数は、文字列を指定した区切り文字で分割し、複数の部分文字列からなる配列を生成します。
7 * `limit`引数を使用すると、生成される配列の要素数を制限できます。
8 *
9 * @param string $text 分割する元の文字列。
10 * @return void 出力例を表示するため戻り値なし。
11 */
12function demonstrateExplode(string $text): void
13{
14    echo "--- explode関数の使用例 ---\n\n";
15    echo "元の文字列: '" . $text . "'\n\n";
16
17    // 1. 基本的な使用例: カンマ (',') で文字列を分割する
18    // 結果として、複数の要素を持つ配列が生成されます。
19    $partsByComma = explode(',', $text);
20    echo "1. カンマ (',') で分割した結果:\n";
21    print_r($partsByComma);
22    echo "\n";
23
24    // 2. limit引数を使った例: 分割数を制限する
25    // `limit`に2を指定すると、最初の区切り文字で分割され、
26    // 残りの部分は最後の要素にまとめられます。
27    $partsWithLimit = explode(',', $text, 2);
28    echo "2. カンマ (',') で分割し、limitを2にした結果:\n";
29    print_r($partsWithLimit);
30    echo "\n";
31
32    // 3. 区切り文字が文字列中に見つからない場合の例
33    // この場合、元の文字列全体が1つの要素として配列に格納されます。
34    $textNoSeparator = "apple-banana-orange";
35    $partsNoSeparator = explode(';', $textNoSeparator); // セミコロンで分割
36    echo "3. 区切り文字が見つからない文字列 ('" . $textNoSeparator . "') をセミコロン (';') で分割した結果:\n";
37    print_r($partsNoSeparator);
38    echo "\n";
39
40    // 4. 空の文字列を分割対象とした場合の例
41    // この場合、1つの空文字列からなる配列が返されます。
42    $emptyString = "";
43    $partsFromEmpty = explode(',', $emptyString);
44    echo "4. 空の文字列 ('') をカンマ (',') で分割した結果:\n";
45    print_r($partsFromEmpty);
46    echo "\n";
47}
48
49// サンプル文字列を用意
50$sampleString = "apple,banana,orange,grape";
51
52// 関数を実行して結果を表示
53demonstrateExplode($sampleString);
54
55?>

PHPのexplode関数は、文字列を特定の区切り文字で複数の部分に分割し、その結果を配列として返す関数です。ログ解析やCSVデータの処理など、文字列データを構造化する際によく利用されます。

この関数は主に3つの引数を取ります。最初の$separator引数には、文字列を分割する区切り文字を文字列で指定します。次に$string引数には、分割したい元の文字列を指定します。そしてオプションの$limit引数には、生成される配列の要素数を最大でいくつにするかを整数値で指定できます。$limitを指定しない場合、すべての区切り文字で分割され、文字列中の区切り文字の数に応じた要素数を持つ配列が返されます。

戻り値は通常、分割された部分文字列を要素とする配列です。例えば、「apple,banana,orange」をカンマで分割すると、['apple', 'banana', 'orange']という配列が返されます。もし指定した区切り文字が元の文字列中に見つからない場合でも、元の文字列全体を1つの要素として含む配列が返されます。また、分割対象の文字列が空の場合、空文字列を1つの要素とする配列が返されます。$limitに2を指定すると、最初の区切り文字で分割された後、残りの部分はまとめて最後の要素として格納されるため、結果の配列は最大で2つの要素を持つことになります。関数が失敗した場合、falseが返される可能性があります。

explode関数は、文字列を特定の区切り文字で分割し、その部分文字列を要素とする配列を返します。区切り文字が元の文字列中に見つからない場合でもエラーにならず、元の文字列全体を1つの要素として含む配列が返されますのでご注意ください。また、分割対象の文字列が空の場合には、空文字列を1つ含む配列が返されます。

第三引数のlimitを指定すると、分割される要素の数を制限できます。このlimitに達すると、残りの文字列は分割されずに最後の要素としてまとめられます。この挙動を理解しておくことで、意図しない配列の構造になることを防ぎ、安全にコードを利用できます。

PHP explode関数で文字列を配列に分割する

1<?php
2
3/**
4 * PHPのexplode関数の基本的な使い方と応用例を示します。
5 * システムエンジニアを目指す初心者向けに、正確で簡潔なコードです。
6 *
7 * explode関数は、文字列を指定した区切り文字で分割し、配列として返します。
8 *
9 * @return void
10 */
11function demonstrateExplodeExamples(): void
12{
13    echo "--- explode関数の基本的な使い方 ---\n";
14
15    // 1. 最も基本的な使い方: 文字列をカンマで分割する
16    $csvString = "apple,banana,orange";
17    $fruits = explode(",", $csvString);
18    echo "元の文字列: \"{$csvString}\"\n";
19    echo "カンマで分割した結果:\n";
20    print_r($fruits); // => Array ( [0] => apple [1] => banana [2] => orange )
21    echo "\n";
22
23    // 2. スペースで文字列を分割する例
24    $sentence = "Hello World from PHP";
25    $words = explode(" ", $sentence);
26    echo "元の文字列: \"{$sentence}\"\n";
27    echo "スペースで分割した結果:\n";
28    print_r($words); // => Array ( [0] => Hello [1] => World [2] => from [3] => PHP )
29    echo "\n";
30
31    echo "--- limit引数の使い方 ---\n";
32
33    // 3. limit引数 (正の値) の使用例: 最大3つの要素に分割する
34    //    残りの文字列は最後の要素として格納されます。
35    $pathString = "/usr/local/bin/php";
36    $pathPartsLimited = explode("/", $pathString, 3);
37    echo "元の文字列: \"{$pathString}\"\n";
38    echo "スラッシュで分割 (limit=3) した結果:\n";
39    print_r($pathPartsLimited); // => Array ( [0] => [1] => usr [2] => local/bin/php )
40    echo "\n";
41
42    // 4. limit引数 (負の値) の使用例: 最後の2つの要素を除外して分割する
43    $dataString = "item1|item2|item3|item4|item5";
44    $dataPartsExceptLast = explode("|", $dataString, -2);
45    echo "元の文字列: \"{$dataString}\"\n";
46    echo "パイプで分割 (limit=-2、最後の2要素を除外) した結果:\n";
47    print_r($dataPartsExceptLast); // => Array ( [0] => item1 [1] => item2 [2] => item3 )
48    echo "\n";
49
50    echo "--- 特殊なケース ---\n";
51
52    // 5. 区切り文字が文字列中に見つからない場合:
53    //    文字列全体が1つの要素として含まれる配列が返されます。
54    $noSeparatorString = "this_string_has_no_commas";
55    $resultNoSeparator = explode(",", $noSeparatorString);
56    echo "元の文字列: \"{$noSeparatorString}\"\n";
57    echo "カンマが見つからない場合の分割結果:\n";
58    print_r($resultNoSeparator); // => Array ( [0] => this_string_has_no_commas )
59    echo "\n";
60
61    // 6. 区切り文字に空文字列 ("") を指定した場合:
62    //    PHPはfalseを返すため、結果をチェックする必要があります。
63    $stringToSplit = "example";
64    $emptySeparatorResult = explode("", $stringToSplit);
65    echo "元の文字列: \"{$stringToSplit}\"\n";
66    echo "区切り文字に空文字列を指定した場合 (explode(\"\", \"example\")):\n";
67    if ($emptySeparatorResult === false) {
68        echo "結果: false (PHPでは空文字列をexplode関数の区切り文字に指定することはできません)\n";
69    } else {
70        print_r($emptySeparatorResult);
71    }
72    echo "\n";
73}
74
75// 定義した関数を実行して、explode関数の動作を確認します。
76demonstrateExplodeExamples();

PHPのexplode関数は、与えられた文字列を指定した区切り文字で分割し、その結果を配列として返す関数です。この関数は、文字列データを扱いやすい形式に変換する際によく利用されます。

引数としては、最初に区切り文字となるstring($separator)を、次に分割対象のstring($string)を指定します。さらに、オプションとして分割する要素の最大数を示すint($limit)を設定できます。$limitが正の値の場合、配列の要素数はその値を超えず、残りの文字列は最後の要素として格納されます。負の値を指定すると、配列の最後から指定した数の要素が除外されます。戻り値は、分割された文字列の配列(array)ですが、区切り文字に空文字列("")が指定された場合はfalseを返します。

サンプルコードでは、まず「apple,banana,orange」のような文字列をカンマで分割する基本的な使い方を示し、['apple', 'banana', 'orange']という配列が得られることを確認できます。また、スペース区切りや、/usr/local/bin/phpのようなパス文字列をスラッシュで分割する例も紹介しています。

特に$limit引数の挙動は重要です。正のlimitを指定すると、例えば/usr/local/bin/phpを3つに分割する場合、['', 'usr', 'local/bin/php']のように、残りの部分が最後の要素に結合されます。負のlimitでは、最後の指定した要素数を除外した結果が得られます。

区切り文字が元の文字列に見つからない場合、元の文字列全体が1つの要素として配列に格納されます。一方で、区切り文字に空文字列を指定すると、explode関数はfalseを返すため、利用時にはこの結果を適切に処理することが大切です。

explode関数は、区切り文字に空文字列を指定するとPHP 8ではValueErrorが発生し、falseが返るため、必ず戻り値をチェックしてください。limit引数は分割される配列の要素数を制御し、正の値を指定すると最大要素数が、負の値を指定すると最後の要素が除外されます。特に負の値の挙動は直感的ではないため注意が必要です。また、区切り文字が見つからなかった場合でもエラーにはならず、元の文字列全体が単一要素の配列として返されます。これらの点を理解し、安全に利用してください。

関連コンテンツ

関連プログラミング言語