php程序优化求建议,执行速度太慢
<?php<br /> header("Content-type: text/html; charset=utf-8");<br /> $file = dirname(__FILE__)."/siji.txt"; //四级词库文件<br /> if(!file_exists($file)){<br /> echo 'Not exist';<br /> }<br /> else {<br /> $a = array();//存放英汉对照对儿的数组<br /> $lines = file($file);//读取txt到数组,一行为一个英汉对照对<br /> foreach ($lines as $k=>$v){<br /> if(preg_match('/[a-zA-Z]/',$v))//有的行是标题之类的,不是英汉对照,判断后不加到数组a里面<br /> $a[$k] = trim($v);//因为有换行符,去掉<br /> }<br /> $b = array();//2维数组,$b[n][0]为英文,$b[n][1]为释义<br /> foreach($a as $k=>$v){//把a数组的英汉分离,填充到b数组的第二维内<br /> preg_match('/([a-zA-Z]*)\s(.*)/',$v,$matches);//正则英汉分离,matches[1]是英文,matches[2]是释义中文<br /> $b[$k][0] = $matches[1];<br /> $b[$k][1] = $matches[2];<br /> }<br /> $dsn = 'mysql:host=localhost;dbname=test1';<br /> $db = new PDO($dsn,'root','',array(PDO::MYSQL_ATTR_INIT_COMMAND => 'set names utf8'));<br /> foreach($b as $k=>$v){//插入数据库<br /> $db->exec("INSERT INTO siji (en,cn) VALUES ('$v[0]','$v[1]')");//数据库3个字段,id,en是英文,cn是中文<br /> }<br /> <br /> }
$ar = array_map('trim', file('siji.txt', FILE_IGNORE_NEW_LINES <br><font color='#FF8000'>------解决方案--------------------</font><br> FILE_SKIP_EMPTY_LINES ));<br /> foreach($ar as $v){<br /> preg_match('/([a-zA-Z]*)\s(.*)/', $v, $r);<br /> if(isset($r[2])) $b[] = "('$r[1]','$r[2]')";<br /> }<br /> $dsn = 'mysql:host=localhost;dbname=test1';<br /> $db = new PDO($dsn,'root','',array(PDO::MYSQL_ATTR_INIT_COMMAND => 'set names utf8'));<br /> $db->exec('INSERT INTO siji (en,cn) VALUES ' . join(',', $b));