淺談PHP匯入EXCEL檔案
PHP匯入excel的開源檔案有好幾個,我用的是phpExcelReader。
方法如下,直接上代碼:
$filename = $_FILES ['excel'] ['name'];$tmp_name = $_FILES ['excel'] ['tmp_name'];// 儲存上傳檔案if (move_uploaded_file ( $tmp_name, 'upload/' . $filename )) { inputExcel ( $filename );}// 調用Readerrequire_once 'reader.php';// 建立 Reader$data = new Spreadsheet_Excel_Reader ();// 設定文本輸出編碼$data->setOutputEncoding ( 'utf-8' );// 讀取Excel檔案$data->read ( 'upload/' . $filename );// $data->sheets[0]['numRows']為Excel行數// $data->sheets[0]['numCols'] 為Excel列數for($i = 2; $i <= $data->sheets[0]['numRows']; $i ++) { // 從儲存格中擷取資料 $a = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [1] ); $b = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [2] ); $c = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [3] ); $d = mysql_real_escape_string ( $data->sheets [0] ['cells'] [$i] [4] );}
?
這段代碼的功能就是上傳一個excel檔案並擷取其中資料,值得說明的是:
1、excel表格中不要有半形的(小括弧)和[中括弧],因為它擷取資料的時候是直接儲存到一個數組,所以其中的(小括弧)和[中括弧]會影響數組的格式,並引發錯誤,我的做法是把它們替換成全形的(小括弧)和【中括弧】。
2、如果要把從excel中取出的值和資料庫互動的話,我在這裡mysql_real_escape_string (data)直接做了轉義,防止執行資料庫時因為一些符號引起的錯誤。
3、當excel中的資料量比較大的時候,在往資料庫中插入的時候,注意sql語句的長度,PHP字串的長度限制與php.ini中的配置和電腦記憶體有關。
4、$data->setOutputEncoding ( 'utf-8' )可解決中文亂碼的問題。
?