PHP REGEX:学习如何格式化mysql查询(如jquery的语法highligher插件)

时间:2012-03-02 22:07:16

标签: php regex parsing

正如我在标题中所说的那样   我正在学习如何使用php中的正则表达式将语法高亮显示为mysql代码

这是我刚刚尝试的代码

$css    = '<style> body{font-family:tahoma;font-size:12px;}</style>';
$lista  = 'select|insert|update|delete|drop|truncate|alter' ;
$lista2 = 'into|from|values|desc|asc|on' ;
$lista3 = 'where|order by|limit|having|group by|union|left join|right join|full join|outer join|inner join' ;
$code   = preg_replace('/('.$lista.')/i','<br /><span style="color:#f00;">$1</span>',$this->query);
$code   = preg_replace('/('.$lista3.')/i','<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span style="color:#0f0">$1</span>',$code);
$code   = preg_replace('/('.$lista2.')/i','<span style="color:#00f">$1</span>',$code).$css;

我的结果就像这个img

syntax result here

我想用简单的方法来做这件事

但我不应该使用任何插件只是正则表达式来理解它

1 个答案:

答案 0 :(得分:0)

我同意Billy Moon关于解析器的问题,但是如果你真的想使用正则表达式,那么你的工作就已接近工作,你只是忘记了单词边界

$code   = preg_replace('/\b('.$lista.')\b/i','...',$this->query);
$code   = preg_replace('/\b('.$lista3.')\b/i','...',$code);
$code   = preg_replace('/\b('.$lista2.')\b/i','...', $code);