php程序优化求建议,执行速度太慢
本帖最后由 zhuzhaodan 于 2013-06-12 18:06:26 编辑 现有四级词库4000单词txt文档,格式如下
accent n.口音,腔调;重音
acceptable a.可接受的,合意的
acceptance n.接受,验收;承认
access n.接近;通道,入口
accessory n.同谋,从犯;附件
accident n.意外的;事故
accidental a.偶然的;非本质的
现要把英汉分离后分别插入mysql数据库内,代码如下
$v){
if(preg_match('/[a-za-z]/',$v))//有的行是标题之类的,不是英汉对照,判断后不加到数组a里面
$a[$k] = trim($v);//因为有换行符,去掉
}
$b = array();//2维数组,$b[n][0]为英文,$b[n][1]为释义
foreach($a as $k=>$v){//把a数组的英汉分离,填充到b数组的第二维内
preg_match('/([a-za-z]*)\s(.*)/',$v,$matches);//正则英汉分离,matches[1]是英文,matches[2]是释义中文
$b[$k][0] = $matches[1];
$b[$k][1] = $matches[2];
}
$dsn = 'mysql:host=localhost;dbname=test1';
$db = new pdo($dsn,'root','',array(pdo::mysql_attr_init_command => 'set names utf8'));
foreach($b as $k=>$v){//插入数据库
$db->exec(insert into siji (en,cn) values ('$v[0]','$v[1]'));//数据库3个字段,id,en是英文,cn是中文
}
}
程序执行时间2分钟左右,求优化建议~我自己感觉正则那部分应该优化不了多少,主要感觉插进数据库这里费时太多,各位高人有方法请不吝赐教,现在程序执行完毕需要120秒,希望最终优化后能到10秒内,谢谢,4级词库一共才4000对词组,120秒太长了
最终效果图:
高人们,因为我比较新手,所以不管从代码上,还是整体思路上都使这个程序运行缓慢,求优化建议,特别是数据库这里,还有数组这里,或者有更好的办法。100分在这里,谢谢!
分享到:
------解决方案--------------------
不一定能满足要求,但肯定比你的快$ar = array_map('trim', file('siji.txt', file_ignore_new_lines
------解决方案--------------------
file_skip_empty_lines ));
foreach($ar as $v){
preg_match('/([a-za-z]*)\s(.*)/', $v, $r);
if(isset($r[2])) $b[] = ('$r[1]','$r[2]');
}
$dsn = 'mysql:host=localhost;dbname=test1';
$db = new pdo($dsn,'root','',array(pdo::mysql_attr_init_command => 'set names utf8'));
$db->exec('insert into siji (en,cn) values ' . join(',', $b));
------解决方案--------------------
1、将内容格式化成一个类似#1的插入sql语句,保存成*.sql
2、直接用mysql将上面的*.sql导入,php可以用exec
------解决方案--------------------
不好意思, 上面insert少了个t
mysql 的导出语句格式都是用多行insert. 导入速度很快. 一般一条语句2000行记录没问题
------解决方案--------------------
使用参数绑定时,pdo::quote(转义特殊字符)始终都会被执行,并不理会你的数据实际并不包含特殊字符
多出来的时间就是 pdo::quote 的执行时间
