preg_split() 函数通过一个正则表达式分隔字符串。
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 后得到的子串组成的数组。
实例
1、获取搜索字符串的部分
// 使用逗号或空格(包含" ", \r, \t, \n, \f)分隔短语
$keywords = preg_split("/[\s,]+/", "hypertext language, programming");
print_r($keywords);
输出:
Array
(
[0] => hypertext
[1] => language
[2] => programming
)
2、将一个字符串分隔为组成它的字符
$str = 'runoob';
$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
)
3、分隔符也作为返回内容的一部分
$subject = " 123a 5bb 7ccc 88dddd";
$arr = preg_split("/([a-zA-Z]+)\s*/", $subject, null, PREG_SPLIT_DELIM_CAPTURE);
print_r($arr);
输出:
Array
(
[0] => 123
[1] => a
[2] => 5
[3] => bb
[4] => 7
[5] => ccc
[6] => 88
[7] => dddd
[8] =>
)
注意:如果想去掉 空值,可改为
$arr = preg_split("/([a-zA-Z]+)\s*/", $subject, null, PREG_SPLIT_NO_EMPTY|PREG_SPLIT_DELIM_CAPTURE);
输出:
Array
(
[0] => 123
[1] => a
[2] => 5
[3] => bb
[4] => 7
[5] => ccc
[6] => 88
[7] => dddd
)
4、分隔一个字符串并获取每部分的偏移量
$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
)
)