PHP preg_split() 函數

PHP 正則運算式(PCRE)PHP 正則運算式(PCRE)

preg_replace 函數通過一個正則運算式分隔字串。

語法

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

通過一個正則運算式分隔給定字串。

參數說明:

  • $pattern: 用於搜索的模式,字串形式。

  • $subject: 輸入字串。

  • $limit: 可選,如果指定,將限制分隔得到的子串最多只有limit個,返回的最後一個 子串將包含所有剩餘部分。limit值為-1, 0或null時都代表"不限制", 作為php的標準,你可以使用null跳過對flags的設置。

  • $flags: 可選,可以是任何下麵標記的組合(以位或運算 | 組合):

    • PREG_SPLIT_NO_EMPTY: 如果這個標記被設置, preg_split() 將進返回分隔後的非空部分。
    • PREG_SPLIT_DELIM_CAPTURE: 如果這個標記設置了,用於分隔的模式中的括弧運算式將被捕獲並返回。
    • PREG_SPLIT_OFFSET_CAPTURE: 如果這個標記被設置, 對於每一個出現的匹配返回時將會附加字串偏移量. 注意:這將會改變返回數組中的每一個元素, 使其每個元素成為一個由第0 個元素為分隔後的子串,第1個元素為該子串在subject 中的偏移量組成的數組。

返回值

返回一個使用 pattern 邊界分隔 subject 後得到的子串組成的數組。

實例

獲取搜索字串的部分

<?php //使用逗號或空格(包含" ", \r, \t, \n, \f)分隔短語 $keywords = preg_split("/[\s,]+/", "hypertext language, programming"); print_r($keywords); ?>

執行結果如下所示:

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

將一個字串分隔為組成它的字元

<?php $str = 'zaixian'; $chars = preg_split('//', $str, -1, PREG_SPLIT_NO_EMPTY); print_r($chars); ?>

執行結果如下所示:

Array
(
    [0] => r
    [1] => u
    [2] => n
    [3] => o
    [4] => o
    [5] => b
)

分隔一個字串並獲取每部分的偏移量

<?php $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
        )

)

PHP 正則運算式(PCRE)PHP 正則運算式(PCRE)