PHP preg_split() 函數
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 後得到的子串組成的數組。
實例
獲取搜索字串的部分
//使用逗號或空格(包含" ", \r, \t, \n, \f)分隔短語
$keywords = preg_split("/[\s,]+/", "hypertext language, programming");
print_r($keywords);
執行結果如下所示:
Array ( [0] => hypertext [1] => language [2] => programming )
將一個字串分隔為組成它的字元
$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 )
分隔一個字串並獲取每部分的偏移量
$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 ) )