PHPExcel导入导出数据
21-06-02 10:17
356
0
public function exportExcel($expTitle,$expCellName,$expTableData){ $xlsTitle = iconv('utf-8', 'gb2312', $expTitle);//文件名称 $fileName = $expTitle.date('_YmdHis');//or $xlsTitle 文件名称可根据自己情况设定 $cellNum = count($expCellName); $dataNum = count($expTableData); vendor("PHPExcel.PHPExcel"); $objPHPExcel = new \PHPExcel(); $cellName = array('A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK','AL','AM','AN','AO','AP','AQ','AR','AS','AT','AU','AV','AW','AX','AY','AZ'); $objPHPExcel->getActiveSheet(0)->mergeCells('A1:'.$cellName[$cellNum-1].'1');//合并单元格 $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', $expTitle.' Export time:'.date('Y-m-d H:i:s')); for($i=0;$i<$cellNum;$i++){ $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i].'2', $expCellName[$i][1]); } // Miscellaneous glyphs, UTF-8 for($i=0;$i<$dataNum;$i++){ for($j=0;$j<$cellNum;$j++){ $objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j].($i+3), $expTableData[$i][$expCellName[$j][0]]); } } header('pragma:public'); header('Content-type:application/vnd.ms-excel;charset=utf-8;name="'.$xlsTitle.'.xls"'); header("Content-Disposition:attachment;filename=$fileName.xls");//attachment新窗口打印inline本窗口打印 $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); exit; } /** * * 导出Excel */ function expUser(){//导出Excel if(session('userid')!=1){ $this->error('此操作需要超级管理员权限!',U('Index/contacts'),2); } $xlsName = "Contacts"; $xlsCell = array( array('id','账号序列'), array('name','姓名'), array('tname','所属乡镇'), array('danwei','单位'), array('phone','电话') ); $xlsModel = M('Contacts'); $xlsData = $xlsModel->Field('id,tid,name,danwei,phone')->select(); foreach ($xlsData as $k => $v) { $xlsData[$k]['tname']=Gettname($v['tid']); array_splice($xlsData[$k]['tid']); } $this->exportExcel($xlsName,$xlsCell,$xlsData); } /** * * 显示导入页面 ... */ /**实现导入excel **/ function impUser(){ if (!empty($_FILES)) { $upload = new \Think\Upload();// 实例化上传类 $filepath='./Public/Excle/'; $upload->exts = array('xlsx','xls');// 设置附件上传类型 $upload->rootPath = $filepath; // 设置附件上传根目录 $upload->saveName = 'time'; $upload->autoSub = false; if (!$info=$upload->upload()) { $this->error($upload->getError()); } foreach ($info as $key => $value) { unset($info); $info[0]=$value; $info[0]['savepath']=$filepath; } vendor("PHPExcel.PHPExcel"); $file_name=$info[0]['savepath'].$info[0]['savename']; $objReader = \PHPExcel_IOFactory::createReader('Excel5'); $objPHPExcel = $objReader->load($file_name,$encode='utf-8'); $sheet = $objPHPExcel->getSheet(0); $highestRow = $sheet->getHighestRow(); // 取得总行数 $highestColumn = $sheet->getHighestColumn(); // 取得总列数 $j=0; for($i=3;$i<=$highestRow;$i++) { $data['name']= $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue(); $tname= $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue(); $data['tid']=Gettid($tname); $data['danwei']= $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue(); $data['phone']= $objPHPExcel->getActiveSheet()->getCell("E".$i)->getValue(); // if(M('Contacts')->where("name='".$data['name']."' and phone=$data['phone']")->find()){ if(M('Contacts')->where("phone='".$data['phone']."'")->find()){ //如果存在相同联系人。判断条件:电话 两项一致,上面注释的代码是用姓名/电话判断 }else{ M('Contacts')->add($data); $j++; } } unlink($file_name); User_log('批量导入联系人,数量:'.$j); $this->success('导入成功!本次导入联系人数量:'.$j); }else { $this->error("请选择上传的文件"); } }
-
中学教师资格证考试文化素养清晨读书计划
【最终上传版】2020.07.08+传统文化之天文历法(上)陈妍+(笔记)+诗涵.pdf【最终上传版】2020.07.09+传统文化之天文历法(下)+陈妍+(笔... 1177 0 24-08-20 -
RainWallpaper动态壁纸制作软件
RainWallpaper是一款功能十分强大且拥有着可定制性的动态壁纸制作的软件引擎哦,大量优秀且可视化设计器都让用户们可以更好的使用,丰富的... 386 0 21-07-07 -
金盆洗脚城小程序node后端
"金盆洗脚城;node后端_微信小程序模板js代码前台前端H5页面源码+后端后台源码.rar" 这个标题和描述揭示了一个项目资源包,其中包含了用于... 777 0 24-09-12 -
Linux 命令完全手册
这本《Linux 命令完全手册》将涵盖你作为开发者需要用到的 60 个核心 Bash 命令。每个命令都附有代码示例和用法提示。这本手册遵循二... 1115 0 24-05-24 -
王汉宗标楷体空心
986 0 24-07-24 -
jQuery EasyUI1.5.3提供了完整的前端组件集合
easyui是基于jQuery、Angular.、Vue和React的用户界面组件的集合。easyui提供了构建现代交互式javascript应用程序的基本功能。使用easyui,... 1311 0 24-05-24 -
app移动端网页资讯新闻模板
一套比较实用的手机新闻资讯网站模板,wap新闻门户网站整站html模板下载。页面包含首页,评测,资讯,专题,排行榜,类别等16个页面 389 0 21-06-22 -
外卖:实现类似锚点功能
外卖:实现类似锚点功能.zip微信小程序模板源码纯前端静态小程序源码导入就可显示外卖:实现类似锚点功能.zip微信小程序模板源码纯前端静态... 826 0 24-09-19
发表我的评论
共0条评论
- 这篇文章还没有收到评论,赶紧来抢沙发吧~