ThinkPHP는 무료 오픈 소스이며 빠르고 간단한 객체 지향 경량 PHP 개발 프레임워크입니다. Apache2 오픈 소스 계약에 따라 출시되었으며 엔터프라이즈 수준 애플리케이션 개발과 민첩한 웹 애플리케이션 개발을 단순화하기 위해 탄생했습니다. 이 기사에서는 주로 Thinkphp5.0을 가져오고 내보내는 방법을 공유합니다.
먼저 공식 웹사이트 http://phpexcel.codeplex.com/로 이동하여 최신 PHPExcel을 다운로드하세요
Thinkphp 확장 클래스는 일반적으로 확장 아래에 배치됩니다
컨트롤러 호출을 용이하게 하기 위해 가져오기 및 내보내기를 위한 공개 메소드 작성
엑셀 파일 가져오기
/** * 导入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 형식의 엑셀 파일로 변환
/** * 数组转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 방식으로 서버에 업로드한 후, 업로드된 경로에 따라 공개 가져오기를 호출합니다. 메소드는 가져올 엑셀의 파일 경로를 다음과 같이 전달합니다
public function importUser(){ $data=import_excel('./a.xls'); print_r($data); exit; }
위 내용은 Thinkphp5.0 가져오기 및 내보내기에 대한 자세한 설명입니다. 도움이 되었으면 좋겠습니다. 모든 사람.
관련 권장 사항:
thinkphp5에서 데이터베이스에 콘텐츠를 추가하는 방법
ThinkPHP는 PHPExcel을 사용하여 Excel 데이터 가져오기 및 내보내기 전체 예제를 구현합니다
위 내용은 Thinkphp5.0을 가져오고 내보내는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!