从这个字符串:

$input = "Some terms with spaces between";

我该如何制作这个数组?

$output = ['Some', 'terms', 'with', 'spaces', 'between'];
有帮助吗?

解决方案

您可以使用 explode split <代码>使preg_split

explode 使用固定字符串:

$parts = explode(' ', $string);

split preg_split 使用正则表达式:

$parts = split(' +', $string);
$parts = preg_split('/ +/', $string);

基于正则表达式的拆分很有用的示例:

$string = 'foo   bar';  // multiple spaces
var_dump(explode(' ', $string));
var_dump(split(' +', $string));
var_dump(preg_split('/ +/', $string));

其他提示

$parts = explode(" ", $str);
print_r(str_word_count("this is a sentence", 1));

结果:

Array ( [0] => this [1] => is [2] => a [3] => sentence )

只是认为值得一提的是正规表达Gumbo发布了#8212;虽然它很可能足以满足大多数&#8212;可能无法捕获所有白色空间的情况。示例:在下面的字符串中使用批准答案中的正则表达式:

$sentence = "Hello                       my name    is   peter string           splitter";

通过print_r为我提供了以下输出:

Array
(
    [0] => Hello
    [1] => my
    [2] => name
    [3] => is
    [4] => peter
    [5] => string
    [6] =>      splitter
)

当使用以下正则表达式时:

preg_split('/\s+/', $sentence);

为我提供了以下(所需)输出:

Array
(
    [0] => Hello
    [1] => my
    [2] => name
    [3] => is
    [4] => peter
    [5] => string
    [6] => splitter
)

希望它可以帮助任何陷入类似障碍的人,并对其原因感到困惑。

只是一个问题,但你是否试图让json从数据中解脱出来?如果是这样,那么你可能会考虑这样的事情:

return json_encode(explode(' ', $inputString));
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top