1

下面的代码直接取自PHP:preg_split - Manual

Example #1 preg_split() 示例:获取搜索字符串的各个部分

<?php
// split the phrase by any number of commas or space characters,
// which include " ", \r, \t, \n and \f
$keywords = preg_split("/[\s,]+/", "hypertext language, programming");
print_r($keywords);
?>

上面的示例将输出:

Array
(
    [0] => hypertext
    [1] => language
    [2] => programming
)

我正在创建一个标记系统,它允许人们在文本框中输入任何内容,并在返回时处理文本并将其插入数据库。数据可以是一个单词或一个短语,如果输入了多个标签,它将使用逗号分隔。

因此,我希望能够保持“超文本语言”原样,因此只去除字符串开头和结尾的空格以及逗号后的任何空格,而不是可能是短语的单词之间的空格。

4

3 回答 3

6

我认为这是最好的选择。

$keywords = preg_split('/\s*,\s*/', "hypertext language, programming", -1, PREG_SPLIT_NO_EMPTY);

首先“正则表达式要慢得多”是错误的,因为它总是取决于模式。在这种情况下 preg_split() 更快。

第二个preg_split 更具可读性,实践表明更有利可图的选择。把事情简单化。

$b = "hypertext language, programming";

$time = microtime(1);
for ($i=1; $i<100000; $i++)
    $a = array_map('trim', explode(',', $b)); // Split by comma
printf("array_map(trim), explode  = %.2f\n", microtime(1)-$time);

$time = microtime(1);
for ($i=1; $i<100000; $i++)
    $a = preg_split('/\s*,\s*/', $b);     // Split by comma
printf("Preg split = %.2f\n", microtime(1)-$time);

array_map(trim), explode  = 0.32
Preg split = 0.22
于 2015-03-10T13:06:18.190 回答
5

您可以使用array_map(),explode()trim():

<?php
    $keywords = array_map('trim', explode(',', 'hypertext language, programming'));
    print_r($keywords);
?>

这将输出:

Array
(
    [0] => hypertext language
    [1] => programming
)

演示

于 2013-10-24T17:38:42.267 回答
0
$to= xyz@ab.com,aaa@abc.com,bbb@abd.com,cc@abe.com;

$toArr = preg_split('[\,]', $to);
于 2020-09-11T03:35:05.947 回答