一个php代码太多执行太慢,php程序优化求提议,执行速度太慢

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数据库内,代码如下

header("Content-type: text/html; charset=utf-8");

$file = dirname(__FILE__)."/siji.txt";  //四级词库文件

if(!file_exists($file)){

echo 'Not exist';

}

else {

$a = array();//存放英汉对照对儿的数组

$lines = file($file);//读取txt到数组,一行为一个英汉对照对

foreach ($lines as $k=>$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秒太长了

最终效果图:

114617935.jpg

高人们,因为我比较新手,所以不管从代码上,还是整体思路上都使这个程序运行缓慢,求优化建议,特别是数据库这里,还有数组这里,或者有更好的办法。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 的执行时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值