在PHP中拆分字符串

3

如何将这个字符串 '||25||34||73||94||116||128' 拆分成数组 我需要得到以下的数组

array (
 0 => '25',
 1 => '34',
 2 => '73',
 3 => '94',
 4 => '116',
 5 => '128'
)

对于我来说,使用explode("||", $array)没有起作用,我得到了这个数组:

array (
 0 => '',
 1 => '25',
 2 => '34',
 3 => '73',
 4 => '94',
 5 => '116',
 6 => '128',
) 
6个回答

12
$array = explode('||', trim($string, '|'));

5

如果字符串中间可以有空值,解决方案是使用preg_split和它的PREG_SPLIT_NO_EMPTY标志

$str = '||25||34||73||94||116||128';
$array = preg_split('/\|\|/', $str, -1, PREG_SPLIT_NO_EMPTY);
var_dump($array);

我将为您提供:

array
  0 => string '25' (length=2)
  1 => string '34' (length=2)
  2 => string '73' (length=2)
  3 => string '94' (length=2)
  4 => string '116' (length=3)
  5 => string '128' (length=3)

如果字符串中间永远不会有空值,使用explode将更快,即使在调用之前必须删除字符串开头和结尾处的||

2
$str='||25||34||73||94||116||128';
$s = array_filter(explode("||",$str),is_numeric);
print_r($s);

输出

$ php test.php
Array
(
    [1] => 25
    [2] => 34
    [3] => 73
    [4] => 94
    [5] => 116
    [6] => 128
)

如果有一个值为0,会怎么样? - Gumbo

1

既然您之前的问题是如何在MySQL中存储和更新此类字符串...让我们假设您未来的任务之一是查找特定值是否在此数组/字符串中,或者查找/计算所有记录中具有某个值的数量。
在这种情况下,您可能现在想要开始规范化您的表格


0
除了已经提到的解决方案,您还可以在之后过滤掉空值:
$arr = array_filter(explode("||", $str), function($val) { return trim($val) === ""; });

这个例子使用 匿名函数,如果您没有使用 PHP 5.3 或更高版本,则需要替换它,可以使用 create_function

$arr = array_filter(explode("||", $str), create_function('$val', 'return trim($val) === "";'));

或者使用预定义函数:

function isEmptyString($str) {
    return trim($str) === "";
}
$arr = array_filter(explode("||", $str), "isEmptyString");

0

你可以做:

explode('||',substr($str,2));

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接