ThinkPHP是一個免費開源的,快速、簡單的物件導向的輕量級PHP 開發框架,遵循 Apache2 開源協定發布,是為了簡化企業級應用開發和敏捷WEB應用開發而誕生的。這篇文章我們主要跟大家分享Thinkphp5.0如何匯入匯出。
首先去官網http://phpexcel.codeplex.com/下載最新PHPExcel
#Thinkphp擴充類別一般都放在extend下
寫入匯入導出的公用方法,方便再控制器中呼叫
導入excel檔
/** * 导入excel文件 * @param string $file excel文件路径 * @return array excel文件内容数组 */ function import_excel($file){ // 判断文件是什么格式 $type = pathinfo($file); $type = strtolower($type["extension"]); $type=$type==='csv' ? $type : 'Excel5'; ini_set('max_execution_time', '0'); Loader::import('PHPExcel.PHPExcel'); // 判断使用哪种格式 $objReader = PHPExcel_IOFactory::createReader($type); $objPHPExcel = $objReader->load($file); $sheet = $objPHPExcel->getSheet(0); // 取得总行数 $highestRow = $sheet->getHighestRow(); // 取得总列数 $highestColumn = $sheet->getHighestColumn(); //循环读取excel文件,读取一条,插入一条 $data=array(); //从第一行开始读取数据 for($j=1;$j<=$highestRow;$j++){ //从A列读取数据 for($k='A';$k<=$highestColumn;$k++){ // 读取单元格 $data[$j][]=$objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue(); } } return $data; }
#陣列轉xls格式的excel檔
/** * 数组转xls格式的excel文件 * @param array $data 需要生成excel文件的数组 * @param string $filename 生成的excel文件名 * 示例数据: $data = array( array(NULL, 2010, 2011, 2012), array('Q1', 12, 15, 21), array('Q2', 56, 73, 86), array('Q3', 52, 61, 69), array('Q4', 30, 32, 0), ); */ function create_xls($data,$filename='simple.xls'){ ini_set('max_execution_time', '0'); Loader::import('PHPExcel.PHPExcel'); $filename=str_replace('.xls', '', $filename).'.xls'; $phpexcel = new PHPExcel(); $phpexcel->getProperties() ->setCreator("Maarten Balliauw") ->setLastModifiedBy("Maarten Balliauw") ->setTitle("Office 2007 XLSX Test Document") ->setSubject("Office 2007 XLSX Test Document") ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.") ->setKeywords("office 2007 openxml php") ->setCategory("Test result file"); $phpexcel->getActiveSheet()->fromArray($data); $phpexcel->getActiveSheet()->setTitle('Sheet1'); $phpexcel->setActiveSheetIndex(0); header('Content-Type: application/vnd.ms-excel'); header("Content-Disposition: attachment;filename=$filename"); header('Cache-Control: max-age=0'); header('Cache-Control: max-age=1'); header ('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past header ('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT'); // always modified header ('Cache-Control: cache, must-revalidate'); // HTTP/1.1 header ('Pragma: public'); // HTTP/1.0 $objwriter = PHPExcel_IOFactory::createWriter($phpexcel, 'Excel5'); $objwriter->save('php://output'); exit; } 数据转csv格式的excle /** * 数据转csv格式的excle * @param array $data 需要转的数组 * @param string $header 要生成的excel表头 * @param string $filename 生成的excel文件名 * 示例数组: $data = array( '1,2,3,4,5', '6,7,8,9,0', '1,3,5,6,7' ); $header='用户名,密码,头像,性别,手机号'; */ function create_csv($data,$header=null,$filename='simple.csv'){ // 如果手动设置表头;则放在第一行 if (!is_null($header)) { array_unshift($data, $header); } // 防止没有添加文件后缀 $filename=str_replace('.csv', '', $filename).'.csv'; ob_clean(); Header( "Content-type: application/octet-stream "); Header( "Accept-Ranges: bytes "); Header( "Content-Disposition: attachment; filename=".$filename); foreach( $data as $k => $v){ // 如果是二维数组;转成一维 if (is_array($v)) { $v=implode(',', $v); } // 替换掉换行 $v=preg_replace('/\s*/', '', $v); // 解决导出的数字会显示成科学计数法的问题 $v=str_replace(',', "\t,", $v); // 转成gbk以兼容office乱码的问题 echo iconv('UTF-8','GBK',$v)."\t\r\n"; } }
使用範例:
匯入原則:
將要匯入的檔案先透過Thinkphp方法上傳到伺服器,再根據上傳後的路徑去呼叫公共導入方法,傳入要導入的excel的檔案路徑,如下
public function importUser(){ $data=import_excel('./a.xls'); print_r($data); exit; }
以上內容就是Thinkphp5.0導入導出的詳解,希望能幫助大家。
相關推薦:
ThinkPHP使用PHPExcel實作Excel資料匯入匯出完整實例
以上是Thinkphp5.0如何導入匯出的詳細內容。更多資訊請關注PHP中文網其他相關文章!