日期:2014-05-17 浏览次数:20515 次
//提供的数据源
$row = array(
'pv' => 50,
'uv' => 6,
'st' => 650,
'nuv' => 2
);
//需求公式,可能有些量不存在:如no
$gx = '(pv+uv)/(uv-nuv+1)*10+nuv-uv+no/0+3.5';
$gx = preg_replace('/[a-z][a-z_\d]+/i', ' $row[\'${0}\'] ', $gx);//处理过后公式
$str = "@\$s = $gx;";//合法php语句
try{
@eval($str);//str和eval前使用@确保不显示错误,如某个变量不存在,或除数为0等
}catch(Exception $e){}
//这个方结果可求出
//提供的数据源,需要先进行排序,将字符数多的键排前面
$row = array(
'nuv' => 2,
'pv' => 50,
'uv' => 6,
'st' => 650,
);
$search = array_keys($row);
$replace = array_values($row);
function cal()
{
global $search, $replace;
//需求公式,可能有些量不存在:如no
$gx = '(pv+uv)/(uv-nuv+1)*10+nuv-uv+no/0+3.5';
$gx = str_replace($search, $replace, $gx);// 改用str_replace替代preg_replace,效率会高一些
$str = "@\$s = $gx;";//合法php语句
try{
@eval($str);//str和eval前使用@确保不显示错误,如某个变量不存在,或除数为0等
}catch(Exception $e){}
}
$t1 = microtime(true);
for ($i = 0; $i < 10000; $i++)
{
cal();
}
echo microtime(true) - $t1;
// output: 0.18727397918701