PHPで文字列を検索する3つの方法:mb_ereg_search_regs関数、mb_preg_search_regs関数、preg_match_all関数


この関数の動作には、使用される文字エンコーディングが重要です。mb_ereg_search_regs 関数は、以下の方法でエンコーディングを決定します。

  1. 内部エンコーディング
    PHP内部で設定されているエンコーディングを使用します。
  2. mb_regex_encoding() 関数で設定されたエンコーディング
    mb_regex_encoding() 関数を使用して設定されたエンコーディングを使用します。
  3. 引数として指定されたエンコーディング
    mb_ereg_search_regs() 関数の引数としてエンコーディングを指定することができます。

適切なエンコーディングが選択されていない場合、mb_ereg_search_regs 関数は正しく動作しない可能性があります。以下に、mb_ereg_search_regs 関数とエンコーディングに関する例を示します。

例:UTF-8 エンコーディングを使用する

<?php
mb_regex_encoding("UTF-8");

$text = "Hello, 世界";
$pattern = "/\w+/";

$regs = mb_ereg_search_regs($pattern, $text);

var_dump($regs);

この例では、mb_regex_encoding() 関数を使用して "UTF-8" エンコーディングを設定しています。その後、mb_ereg_search_regs 関数を使用して "Hello" と "世界" という2つの単語に一致する部分を検索しています。結果は次のようになります。

array(
    [0] => Hello, 世界,
    [1] => Hello,
    [2] => 世界,
)

例:SJIS エンコーディングを使用する

<?php
mb_internal_encoding("SJIS");

$text = "こんにちは、世界";
$pattern = "/\x{3051}-\x{307f}+/";

$regs = mb_ereg_search_regs($pattern, $text);

var_dump($regs);

この例では、mb_internal_encoding() 関数を使用して "SJIS" エンコーディングを設定しています。その後、mb_ereg_search_regs 関数を使用して、漢字を含む部分文字列に一致する部分を検索しています。結果は次のようになります。

array(
    [0] => こんにちは、世界,
    [1] => こんにちは,
    [2] => 世界,
)
  • mb_ereg_search_regs 関数は、PHP 7.2 以降では非推奨となっています。新しいプロジェクトでは、mb_ereg_search_regs 関数ではなく、mb_preg_search_regs 関数を使用することをお勧めします。
  • マルチバイト文字列を含む正規表現を使用する場合は、適切なエンコーディングに対応した正規表現を使用する必要があります。
  • mb_ereg_search_regs 関数を使用する前に、適切なエンコーディングが設定されていることを確認してください。


<?php
mb_regex_encoding("UTF-8");

$text = "Hello, 世界 How are you?";
$pattern = "/\w+/";

$matches = [];
while (preg_match($pattern, $text, $match)) {
    $matches[] = $match[0];
    $text = substr($text, strlen($match[0]));
}

var_dump($matches);

例:SJIS エンコーディングを使用して、文字列内の漢字を含む部分文字列をすべて検索する

<?php
mb_internal_encoding("SJIS");

$text = "こんにちは、世界 今日はいかがですか?";
$pattern = "/\x{3051}-\x{307f}+/";

$matches = [];
while (preg_match($pattern, $text, $match)) {
    $matches[] = $match[0];
    $text = substr($text, strlen($match[0]));
}

var_dump($matches);

例:mb_ereg_search_regs 関数を使用して、文字列内の単語をすべて検索し、その位置情報を取得する

<?php
mb_regex_encoding("UTF-8");

$text = "Hello, 世界 How are you?";
$pattern = "/\w+/";

$regs = [];
while (mb_ereg_search_regs($pattern, $text, $match)) {
    $regs[] = $match;
    $text = substr($text, strlen($match[0]));
}

var_dump($regs);

説明

  • mb_ereg_search_regs 関数は、PHP 7.2 以降では非推奨となっています。新しいプロジェクトでは、mb_preg_search_regs 関数を使用することをお勧めします。


しかし、mb_ereg_search_regs 関数は PHP 7.2 以降で非推奨 となっています。新しいプロジェクトでは、mb_ereg_search_regs 関数ではなく、以下の方法を使用することをお勧めします。

mb_preg_search_regs 関数

mb_preg_search_regs 関数は、mb_ereg_search_regs 関数とほぼ同じ機能を提供します。mb_preg_search_regs 関数は、PHP 5.0 以降で使用可能であり、mb_ereg_search_regs 関数よりも高速で効率的です。

<?php
mb_regex_encoding("UTF-8");

$text = "Hello, 世界 How are you?";
$pattern = "/\w+/";

$regs = mb_preg_search_regs($pattern, $text);

var_dump($regs);

preg_match_all 関数

preg_match_all 関数は、正規表現を使用して文字列内の一致をすべて検索し、その結果を配列として返します。mb_preg_search_regs 関数とは異なり、preg_match_all 関数はマルチバイト文字列に対応していません。

<?php
$text = "Hello, 世界 How are you?";
$pattern = "/\w+/";

preg_match_all($pattern, $text, $matches);

var_dump($matches);

手動でループする

正規表現を使用して文字列内の一致を検索する方法は他にもありますが、上記の方法が最も一般的です。複雑な正規表現を使用する場合は、手動でループする方が効率的な場合があります。

<?php
$text = "Hello, 世界 How are you?";
$pattern = "/\w+/";

$matches = [];
preg_match_all($pattern, $text, $matches);

foreach ($matches[0] as $match) {
    echo $match . "\n";
}