在'preg-replace()'函数中使用'#'符号时出错

时间:2013-01-21 16:19:07

标签: php preg-replace delimiter

我收到错误,

Warning: preg_replace(): No ending delimiter '#' found

在这一行,

$sql = preg_replace("\n#[^\n]*\n", "\n", $sql);

关于此功能,

function split_sql($sql) {
    $sql = trim($sql);
    $sql = preg_replace("\n#[^\n]*\n", "\n", $sql);

    $buffer = array();
    $ret = array();
    $in_string = false;

    for($i=0; $i<strlen($sql)-1; $i++) {
        if($sql[$i] == ";" && !$in_string) {
            $ret[] = substr($sql, 0, $i);
            $sql = substr($sql, $i + 1);
            $i = 0;
        }

        if($in_string && ($sql[$i] == $in_string) && $buffer[1] != "\\") {
            $in_string = false;
        }
        elseif(!$in_string && ($sql[$i] == '"' || $sql[$i] == "'") && (!isset($buffer[0]) || $buffer[0] != "\\")) {
            $in_string = $sql[$i];
        }
        if(isset($buffer[1])) {
            $buffer[0] = $buffer[1];
        }
        $buffer[1] = $sql[$i];
    }

    if(!empty($sql)) {
        $ret[] = $sql;
    }
    return($ret);
}

1 个答案:

答案 0 :(得分:2)

分隔符必须是非字母数字,非空白字符。由于这个原因,它会将#视为分隔符,因此会查找另一个但无法找到它。

尝试preg_replace("/\n#[^\n]*\n/","\n",$sql);