這篇文章介紹的內容是關於PHP處理excel文件數據,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
文章主要記錄如何使用PHPexcel外掛程式對excel文件進行處理的過程,僅作備忘使用,如插件下載遇到問題,可以留言,謝謝瀏覽。以下是筆記內容:
require_once('./PhpSpreadsheet/vendor/autoload.php');
//创建文件读取类对象 $reader = \PhpOffice\PhpSpreadsheet\IOFactory::createReader("Xlsx"); /** Advise the Reader that we only want to load cell data **/ //设置为只读模式$reader->setReadDataOnly(true); /** Load $inputFileName to a Spreadsheet Object **/ //加载文件路径,路径为绝对路径 $spreadsheet = $reader->load($file_path); //获取excel表中有多少个sheet $sheetNum = $spreadsheet->getSheetCount(); $sheetData = []; $temp = []; //只获取活跃的sheet //$temp = $spreadsheet->getSheetActive()->toArray(null, true, true, true); //遍历每一个sheet,获取里面的数据内容 for($i = 0; $i < $sheetNum; $i++){ $temp = $spreadsheet->getSheet($i)->toArray(null, true, true, true); foreach ($temp as $v) { if(is_float($v['A'])){ $sheetData[] = $v; } } }
輸出格式內容如下:
var_dump($sheetData); /* 'A' => float 41746 'B' => string '玉雪婵娟' (length=12) 'C' => float 236979210 'D' => string '353343073072008' (length=15) 'E' => float 41740 'F' => null*/
//获取excel表中的数据记录 $excel_records$temp = []; $excel_records = []; foreach ($sheetData as $v){ //strtotime(gmdate("Y-m-d", ($sheetData[$i]['F'] -25569) * 86400)) //将表格中的时间字符串转为时间格式 $temp['date'] = gmdate("Y-m-d", ($v['A'] -25569) * 86400);//2018年获取为2014年,尚不明原因 $temp['drname'] = $v['B']; $temp['uid'] = $v['C']; $temp['imei'] = $v['D']; $temp['reg_date'] = $v['E']; $excel_records[] = $temp; }
後續直接對資料進行處理即可。
相關推薦:
以上是PHP處理excel檔案數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!