(PHP 4, PHP 5, PHP 7, PHP 8)
explode — 使用一个字符串分割另一个字符串
$separator
, string $string
, int $limit
= PHP_INT_MAX
): array
此函数返回由字符串组成的数组,每个元素都是
string
的一个子串,它们被字符串
separator
作为边界点分割出来。
separator
边界上的分隔字符。
string
输入的字符串。
limit
如果设置了
limit
参数并且是正数,则返回的数组包含最多
limit
个元素,而最后那个元素将包含
string
的剩余部分。
如果
limit
参数是负数,则返回除了最后的
-limit
个元素外的所有元素。
如果 limit
是 0,则会被当做 1。
注意:
在 PHP 8.0 之前,implode() 可以接收两种参数顺序。 但请注意,explode() 从未支持乱序传入参数:你必须保证
separator
参数在string
参数之前。
此函数返回由字符串组成的 array,每个元素都是
string
的一个子串,它们被字符串
separator
作为边界点分割出来。
如果 separator
为空字符串(""),explode()
将抛出 ValueError。
如果
separator
所包含的值在
string
中找不到,并且使用了负数的 limit
,
那么会返回空的 array,
否则返回包含 string
单个元素的数组。
如果 separator
值出现在了
string
参数的开头或末尾,
将在返回 array 相应的头部或尾部添加 array 空值。
版本 | 说明 |
---|---|
8.0.0 |
现在开始,当 separator 参数传入空字符串时("" ),
explode() 会抛出 ValueError。
在早期版本中,explode() 会返回 false 。
|
示例 #1 explode() 例子
<?php
// 示例 1
$pizza = "piece1 piece2 piece3 piece4 piece5 piece6";
$pieces = explode(" ", $pizza);
echo $pieces[0]; // piece1
echo $pieces[1]; // piece2
// 示例 2
$data = "foo:*:1023:1000::/home/foo:/bin/sh";
list($user, $pass, $uid, $gid, $gecos, $home, $shell) = explode(":", $data);
echo $user; // foo
echo $pass; // *
?>
示例 #2 explode() return examples
<?php
/*
字符串内不包含分隔字符时,
会简单返回只有一个原始字符串元素的 array。
*/
$input1 = "hello";
$input2 = "hello,there";
$input3 = ',';
var_dump( explode( ',', $input1 ) );
var_dump( explode( ',', $input2 ) );
var_dump( explode( ',', $input3 ) );
?>
以上例程会输出:
array(1) ( [0] => string(5) "hello" ) array(2) ( [0] => string(5) "hello" [1] => string(5) "there" ) array(2) ( [0] => string(0) "" [1] => string(0) "" )
示例 #3 limit
参数的例子
<?php
$str = 'one|two|three|four';
// 正数的 limit
print_r(explode('|', $str, 2));
// 负数的 limit
print_r(explode('|', $str, -1));
?>
以上例程会输出:
Array ( [0] => one [1] => two|three|four ) Array ( [0] => one [1] => two [2] => three )
注意: 此函数可安全用于二进制对象。