ホームページ  >  記事  >  バックエンド開発  >  PHPプログラムの最適化についてアドバイスをお願いします。実行速度が遅すぎます。

PHPプログラムの最適化についてアドバイスをお願いします。実行速度が遅すぎます。

WBOY
WBOYオリジナル
2016-06-13 12:45:001147ブラウズ

PHP プログラムの最適化についてアドバイスをお願いします。実行速度が遅すぎます

この投稿は zhuzhaodan によって最終編集されました: 2013-06-12 18:06:26 現在、4,000 単語の 4 レベルの辞書次の形式の txt ドキュメントがあります
アクセント n.アクセント、アクセント
許容できる a. 許容できる、望ましい
受け入れ n. 受け入れ、承認
アクセス n. 通路、入口
アクセサリー n. 共犯者、付属品
事故 n. 予期せぬ事故
偶発的 a. 必須ではない

ここで、英語と中国語を分離して、それぞれを mySQL データベースに挿入する必要があります。コードは次のとおりです。
<?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 />
}


プログラムの実行時間は2分程度です。最適化のアドバイスをお願いします。個人的にはデータベースへの挿入に時間がかかりすぎると感じています。ご自由に教えてください。プログラムの実行には 120 秒 かかります。最終的な最適化後は 10 秒以内に完了することを願っています。ありがとうございます。レベル 4 の語彙データベースには 4,000 ペアしかありません。合計フレーズ数、120 秒は長すぎます

最終レンダリング:


専門家の皆様、私は比較的初心者なので、コードと全体的な考え方の両方でこのプログラムの実行が遅いのですが、特にデータベース配列についての最適化に関する提案をお願いします。 . またはより良い方法があります。ここで100ポイントです、ありがとう!
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。