関数・クラス解説

preg_split

version:PHP 4, PHP 5, PHP 7 (公式)

正規表現で文字列を分割する

公式リファレンス

書式

preg_split ( string $pattern , string $subject [, int $limit = -1 [, int $flags = 0 ]] ) : array|false

説明

指定した文字列を、正規表現で分割します。

パラメータ

pattern
検索するパターンを表す文字列。
subject
入力文字列。
limit
これを指定した場合、最大 limit 個の部分文字列を返します。 残りの文字列は、最後の部分文字列に含めて返されます。 limit が -1 あるいは 0 の場合は「制限が無い」ことを意味します。
flags
flags は、次のフラグを組み合わせたものとする (ビット和演算子 | で組み合わせる)ことが可能です。
PREG_SPLIT_NO_EMPTY
このフラグを設定すると、空文字列でないものだけが preg_split() により返されます。
PREG_SPLIT_DELIM_CAPTURE
このフラグを設定すると、文字列分割用のパターン中の カッコによるサブパターンでキャプチャされた値も同時に返されます。
PREG_SPLIT_OFFSET_CAPTURE
このフラグを設定した場合、各マッチに対応する文字列のオフセットも返されます。 これにより、返り値は配列となり、配列の要素 0 はマッチした文字列、 要素 1 は subject におけるマッチした文字列のオフセット値となることに 注意してください。

返値

pattern にマッチした境界で分割した subject の部分文字列の配列を返します。失敗した場合に FALSE を返します。

注意

ヒント 正規表現の威力を必要としないのなら、より高速な (機能はシンプルですが) 代替関数として explode() あるいは str_split() のような選択肢があります。 ヒント マッチングに失敗した場合は、要素が一つだけの配列を返します。その要素の内容は、入力文字列そのままになります。

サンプル

例1 preg_split() の例 : 検索文字列のある部分を取得

// カンマまたは " ", \r, \t, \n , \f などの空白文字で句を分割する。 $keywords = preg_split("/[\s,]+/", "hypertext language, programming"); print_r($keywords);

上の例の出力は以下となります。

Array ( [0] => hypertext [1] => language [2] => programming )

例2 文字列を文字要素に分割

$str = 'string'; $chars = preg_split('//', $str, -1, PREG_SPLIT_NO_EMPTY); print_r($chars);

上の例の出力は以下となります。

Array ( [0] => s [1] => t [2] => r [3] => i [4] => n [5] => g )

例3 文字列をマッチするものとそのオフセットに分割

$str = 'hypertext language programming'; $chars = preg_split('/ /', $str, -1, PREG_SPLIT_OFFSET_CAPTURE); print_r($chars);

上の例の出力は以下となります。

Array ( [0] => Array ( [0] => hypertext [1] => 0 ) [1] => Array ( [0] => language [1] => 10 ) [2] => Array ( [0] => programming [1] => 19 ) )

参考

  • PCRE のパターン
  • preg_quote() - 正規表現文字をクオートする
  • implode() - 配列要素を文字列により連結する
  • preg_match() - 正規表現によるマッチングを行う
  • preg_match_all() - 繰り返し正規表現検索を行う
  • preg_replace() - 正規表現検索および置換を行う
  • preg_last_error() - 直近の PCRE 正規表現処理のエラーコードを返す
  • ワード検索


    ※入力キーワードが、関数名・説明文・タグに含まれるものを検索

    関数名アルファベット別

    A B C D E F G H I J
    K L M N O P Q R S T
    U V W X Y Z _

    最終更新一覧

    stristr
     大文字小文字を区別せず文字列を検索し、ヒット箇所以降(あるいは以前)の文字列を返却

    stripslashes
     バックスラッシュでエスケープされた文字列から、バックスラッシュを取り除く

    stripos
     大文字小文字を区別せずに文字列が最初に現れる位置を取得する

    stripcslashes
     addcslashes() でクォートされた文字列をアンクォートする

    strip_tags
     文字列から HTML と PHP のタグを除去して返却

    strcspn
     指定した文字が最初に現れる位置を調べる

    strcoll
     ロケールに基づいて2つの文字列を比較し同じか(あるいは大小)を判定する

    strcmp
     2つの文字列を比較し同じか(あるいは大小)を判定する

    strchr
     strstr() のエイリアス

    strcasecmp
     2つの文字列を比較(大文字小文字を区別せず同じとみなす)

    カテゴリー一覧

    PHP の振る舞いの変更
    音声フォーマットの操作
    認証サービス
    コマンドライン関連
    圧縮およびアーカイブ
    暗号
    データベース関連
    日付および時刻関連
    ファイルシステム
    自然言語および文字エンコーディング
    画像処理および作成
    メール関連
    数学
    テキスト以外の MIME 型
    プロセス制御
    その他の基本モジュール
    その他のサービス
    検索エンジン用の拡張モジュール
    サーバー固有のモジュール
    セッション関連
    テキスト処理
    変数・データ型関連
    ウェブサービス
    Windows 用のモジュール
    XML 操作
    GUI用の拡張モジュール