在PHP中拆分字符串,但不包括花括号内的', '。

3
我有一个这样的字符串 -
$str = "field1.id as field1, 
       DATE_SUB(field2, INTERVAL (DAYOFMONTH(field2)-1) DAY) as field2,   
       field3.name as field3";

需要用,将其拆分为数组,如下所示:

$requiredArray = array(
  0 => field1.id as field1,
  1 => DATE_SUB(field2, INTERVAL (DAYOFMONTH(field2)-1) DAY) as field2
  2 => field3.name as field3
);

我试过使用explode,但它不起作用:
$requiredArray = explode(', ', $str); 
// doesn't work as "DATE_SUB(field2, INTERVAL ..." also gets exploded

有什么技巧/想法吗?


4
你需要使用 preg_split 函数来判断逗号是否在括号内,只有在不在括号内时才进行分割。或者使用类似于 preg_match_all('#\(.*?\)|[^,]+#', $str, $matches); var_dump($matches[0]); 的方式实现。 - Mark Baker
好提示,谢谢,我会尝试一下。+1 - jitendrapurohit
@MarkBaker 现在那个不起作用 :(。 - jitendrapurohit
使用正则表达式的原则仍然适用,只是找到正确的正则表达式是个问题;我会看看能找到什么。 - Mark Baker
这并不像我想象的那么明显。有人可以帮我吗?尝试了几次后还是不起作用 :( - jitendrapurohit
显示剩余6条评论
2个回答

4

请尝试这个。

$str = "field1.id as field1, 
       DATE_SUB(field2, INTERVAL (DAYOFMONTH(field2)-1) DAY) as field2,   
       field3.name as field3";

$buffer = '';
$stack = array();
$depth = 0;
$len = strlen($str);
for ($i=0; $i<$len; $i++) {
    $char = $str[$i];
    switch ($char) {
    case '(':
        $depth++;
        break;
    case ',':
        if (!$depth) {
            if ($buffer !== '') {
                $stack[] = $buffer;
                $buffer = '';
            }
            continue 2;
        }
        break;
    case ' ':
        if (!$depth) {
             $buffer .= ' ';
            continue 2;
        }
        break;
    case ')':
        if ($depth) {
            $depth--;
        } else {
            $stack[] = $buffer.$char;
            $buffer = '';
            continue 2;
        }
        break;
    }
    $buffer .= $char;
}
if ($buffer !== '') {
    $stack[] = $buffer;
}
echo "<pre>";
print_r($stack);
echo "</pre>";

是的,我不认为正则表达式现在可以做到这一点。虽然这是一个更大的解决方案,但我会选择它。谢谢! - jitendrapurohit
http://stackoverflow.com/questions/4538086/preg-split-by-comma-ignore-parentheses-php/4538153#4538153 也可以正常工作 :) - jitendrapurohit

-1

试试这个:

preg_match_all('~(.*)[^(],?~', $str, $matches);

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