搜尋
首頁php教程php手册Thinkphp 用PHPExcel 導入Excel

搞了個簡單的Excel導入, 用的是PHPExcel(百科:用來操作Office Excel文檔的一個PHP類庫, 基於微軟的OpenXML標準和PHP語言)

好, 不說了, 開始吧...

首先得有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             }


接著跑下去, 導入的是PHPExcel.php和PHPExcel/IOFactory.php這兩個檔案


因為是導入嘛,所以就呼叫createReader方法

1 //导入PHPExcel 和 IOFactory类
2 Vendor('PHPExcel.PHPExcel');
3 Vendor('PHPExcel.PHPExcel.IOFactory');



這裡說的是遍歷行數, 從A到E(自己定義的,要取哪就取哪) 這裡i要從2開始, 因為第一行是表頭, 不是數據

$objReader = \PHPExcel_IOFactory::createReader('Excel5');



測試表是這樣的



現在印個$allData出來看看

 

>導入前得作個小判斷. 例如我想如果資料庫裡的電話跟我想要導入的資料有相同的話, 就不要導入 類似這樣的-> 大神們還有沒有什麼好一點的方法

$objPHPExcel = $objReader -> load($file_path, $encode='utf-8');

 導入時, 有兩種方法一是拼接sql 二是用foreach循環來導入

實測第一種要快得多!!!強烈建議拼接導入...不過如果導入的sql導入...不過如果導入的sql資料過大, 拼接起來的sql會很長, 因此資料會比較大...

 有時會報執行檔逾時的錯誤或是遇到1153 – Got a packet bigger than 'max_allowed_pa​​cket' bytes OR

伺服器直接掛了 這樣的報錯

這樣你就要需要修改my.ini 裡的max_allowed_pa​​cket把它稍設大一點就可以了,重啟MySql


 OK..等待片刻, 差不多2W的數據就導進去了(^ _^)

以上是我寫的插入語句

 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);

, 也望懇請各位指出. 

 以上就是Thinkphp 用PHPExcel 導入Excel的內容,更多相關內容請關注PHP中文網(www.php.cn)!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),