PHPExcel (百科事典: Microsoft の OpenXML 標準と PHP 言語に基づいて、Office Excel ドキュメントを操作するために使用される PHP クラス ライブラリ) を使用して、簡単な Excel インポートを作成しました
さて、もうやめましょう...
まずはあなたPHPExcel クラス ライブラリが必要です。ここをクリックして https://github.com/Zmwherein/PHPExcel.git をダウンロードします
次に、それを ThinkPHPLibraryVendor に置きます (個人的な好みで、インポートするだけです)
以下に示すように:
PHPExcel.phpエントリーファイルに似ています。そこに書かれたメソッドがどのように実行されるかを確認できます...
これがインターフェースです:
まず、ファイルがアップロードされているかどうかを判断しましょう(実際には)。 、ここのものはまだ機能するはずです)最適化してより良く書くことができますが、当面は私の個人的な能力には限界があります)
1 public function import() 2 { 3 // p($data_in_db); 4 if ( ! empty($_FILES)) 5 { 6 $upload = new \Think\Upload(); 7 $upload -> maxSize = 3145728 ; 8 $upload -> exts = array('xlsx', 'xls'); 9 $upload -> rootPath = './'; // 设置附件上传根目录 10 $upload -> savePath = '/Upload/excel/'; // 设置附件上传(子)目录 11 $upload -> subName = false; 12 $upload -> saveName = 'time'; 13 14 $info = $upload -> uploadOne($_FILES['import']); 15 16 if( ! $info) 17 { 18 $this->error($upload->getError()); 19 }
次に、2つのファイルPHPExcel.phpとPHPExcel/IOFactoryを実行してインポートしました.php
1 //导入PHPExcel 和 IOFactory类 2 Vendor('PHPExcel.PHPExcel'); 3 Vendor('PHPExcel.PHPExcel.IOFactory');
インポートなのでcreateReaderメソッドを呼び出します
$objReader = \PHPExcel_IOFactory::createReader('Excel5');
アップロードされたファイルがどこにあるか、つまりロードするパスを設定しますファイル
$objPHPExcel = $objReader -> load($file_path, $encode='utf-8');
ここで話しているのは、A から E までの走査される行数です (自分で定義し、好きな方を選択してください) 最初の行は 2 から始める必要があります。はヘッダーであり、データではありません
1 $sheet = $objPHPExcel -> getSheet(0); 2 $highestRow = $sheet -> getHighestRow(); // 取得总行数 3 // p($highestRow); 4 // $highestColumn = $sheet->getHighestColumn(); // 取得总列数 5 6 for($i=2;$i getActiveSheet() -> getCell("A".$i)->getValue(); 9 $data['company'] = $objPHPExcel -> getActiveSheet() -> getCell("B".$i)->getValue(); 10 $data['mobile'] = $objPHPExcel -> getActiveSheet() -> getCell("C".$i)->getValue(); 11 $data['category'] = $objPHPExcel -> getActiveSheet() -> getCell("D".$i)->getValue(); 12 $data['mark'] = $objPHPExcel -> getActiveSheet() -> getCell("E".$i)->getValue(); 13 14 $allData[] = $data; 15 } 16 // p($allData);
テストテーブルは次のようになります
$allDataを出力して確認してください
ほら、データが出てきました...
次のステップは、それをデータベースにインポートすることです - >たとえば、データベース内の電話番号がインポートしたいデータと同じかどうかを判断する必要があります。インポート、このようなものはインポートしたくないです -> 誰かより良い方法を持っていますか
1 if (empty($allData)) 2 { 3 $this -> error(C('MESSAGE.ERROR_NODATA')); 4 } 5 $data_in_db = M('Excel') -> field('mobile') -> select();//表Excel里所有数据 6 foreach ($data_in_db as $key => $val) 7 { 8 foreach ($allData as $k => $v) 9 { 10 if ($val['mobile'] == $v['mobile']) 11 { 12 unset($allData[$k]); 13 } 14 } 15 }
インポートするとき、2つの方法があります: 1つはSQLを結合することであり、もう1つはforeach ループを使用してインポートします
最初の方法の方がはるかに高速です!!! SQL を結合してインポートすることを強くお勧めします...ただし、インポートされたデータが大きすぎて、結合された SQL が非常に長くなる場合があります。データは比較的大きくなります...
場合によっては、実行ファイルのタイムアウト エラーが報告されるか、「1153 – ‘max_allowed_packet」バイトを超えた場合、または
このようなエラーが報告されます。
この場合、my.ini の max_allowed_packet を変更して少し大きく設定する必要があります。MySql を再起動します OK.. しばらく待つと、ほぼ 2W のデータがインポートされます (^_^)。1 $sql = "INSERT INTO `db_excel` (". implode(',',array_keys($allData[0])) .") VALUES "; 2 foreach ($allData as $key => $val) 3 { 4 $sql .= "("; 5 $sql .= "'".implode("','", $val)."'"; 6 $sql .= "),"; 7 } 8 $sql = rtrim($sql,','); 9 // 出错返回false 否则返回成功行数 10 $res = D('Excel') -> execute($sql); 11 if ($res === false) 12 { 13 $this -> error(C('MESSAGE.ERROR_IMPORT')); 14 } 15 else if ($res > 0) 16 { 17 $this -> success(C('MESSAGE.SUCCESS_IMPORT'), U('Excel/index')); 18 } 19 else if ($res === 0) 20 { 21 $this -> success(C('MESSAGE.SUCCESS_IMPORT_0'), U('Excel/index')); 22 }
まだ多くの欠点がありますが、よろしくお願いします。
上記は、PHPExcel を使用して Excel をインポートする Thinkphp の内容です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) に注目してください。
thinkphp是国产框架。ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,是为了简化企业级应用开发和敏捷WEB应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了关于使用think-queue来实现普通队列和延迟队列的相关内容,think-queue是thinkphp官方提供的一个消息队列服务,下面一起来看一下,希望对大家有帮助。

thinkphp基于的mvc分别是指:1、m是model的缩写,表示模型,用于数据处理;2、v是view的缩写,表示视图,由View类和模板文件组成;3、c是controller的缩写,表示控制器,用于逻辑处理。mvc设计模式是一种编程思想,是一种将应用程序的逻辑层和表现层进行分离的方法。

thinkphp查询库是否存在的方法:1、打开相应的tp文件;2、通过“ $isTable=db()->query('SHOW TABLES LIKE '."'".$data['table_name']."'");if($isTable){...}else{...}”方式验证表是否存在即可。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了使用jwt认证的问题,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于ThinkPHP的相关知识,其中主要整理了使用think-queue实现redis消息队列的相关问题,下面一起来看一下,希望对大家有帮助。

thinkphp扩展有:1、think-migration,是一种数据库迁移工具;2、think-orm,是一种ORM类库扩展;3、think-oracle,是一种Oracle驱动扩展;4、think-mongo,一种MongoDb扩展;5、think-soar,一种SQL语句优化扩展;6、porter,一种数据库管理工具;7、tp-jwt-auth,一个jwt身份验证扩展包。

在thinkphp3.2中,可以利用define关闭调试模式,该标签用于变量和常量的定义,将入口文件中定义调试模式设为FALSE即可,语法为“define('APP_DEBUG', false);”;开启调试模式将参数值设置为true即可。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 中国語版
中国語版、とても使いやすい

WebStorm Mac版
便利なJavaScript開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

ホットトピック



