thinkphp5.1 phpexcel 批量导入导出

1.批量导入

public function importExcel(){$authority = $this->getUserAuthority('order_input', 'batch_import');if ($authority['code'] != 0) {return json($authority);}$file = request()->file('files');if(empty($file)){return printMsg(-1, "请上传文件");}// 移动到框架应用根目录/uploads/ 目录下//$info = $file->validate(['size'=>(100*1024*1024),'ext'=>'xls,xlsx'])->move('static/uploads/');$ext_arr = ['xlsx'];//接收文件$file_type = $file->getInfo()['name'];//获取后缀$ext = explode('.', $file_type);$ext = end($ext);//判断时候是限制的文件格式if (!in_array($ext, $ext_arr)) {return printMsg(-1,'文件格式有误,只支持Excel2007,xlsx后缀的文件');}//实例化类库 // 读取excel文件require_once './../extend/PHPExcel/IOFactory.php';require_once './../extend/PHPExcel/PHPExcel.php';if ($ext == 'xls') {$PHPReader = new \PHPExcel_Reader_Excel5();} elseif ($ext == 'xlsx') {$PHPReader = new \PHPExcel_Reader_Excel2007();}$tmp_name = $file->getInfo()['tmp_name'];$objData = $PHPReader->load($tmp_name, $encode = 'utf-8');$excel_array = $objData->getsheet(0)->toArray();//删除表格第一行unset($excel_array[0]);$insertData = [];$userInfo = $this->getTokenUser();$date = date('Y-m-d H:i:s', $this->request->time());if (count($excel_array) > 500){return printMsg(-1,'批量导入行数不能大于500条');}//todo 线上对应的数据$project_name_id = 13;$source = '腾讯游戏';$project_source_detail_id = 115;$depargroup = 29;$designer_uid = 1114;Db::startTrans();try {foreach ($excel_array as $key => $value) {$line = $key+1;try {$d2 = date("Y-m-d",($value[2] - 25569) * 86400);$d3 = date("Y-m-d",($value[3] - 25569) * 86400);$d5 = date("Ym",($value[5] - 25569) * 86400);}catch (Exception $exception){Db::rollback();return printMsg(-1, "第".$line."行,日期格错误");}$line = $key+1;if (empty($value[0])){Db::rollback();return printMsg(-1, "第".$line."行,单号不能为空");}if (empty($value[1])){Db::rollback();return printMsg(-1, "第".$line."行,需求名称不能为空");}if (!$this->isDate($d2)){Db::rollback();return printMsg(-1, "第".$line."行,需求开始日期格式不正确");}if (!$this->isDate($d3)){Db::rollback();return printMsg(-1, "第".$line."行,需求结束日期格式不正确");}if (!is_numeric($value[4])){Db::rollback();return printMsg(-1, "第".$line."行,价格格式不正确");}if (!$this->isDate2($d5)){Db::rollback();return printMsg(-1, "第".$line."行,需求归属日期格式不正确");}$achievementData = ["type"         => 1, #1:报价"project_name" => $project_name_id,"project_name_id" => $project_name_id,"demand_name"  => $value[1],"demander"     => '腾讯',"start_time"   =>  $d2,"end_time"     =>  $d3,"user_id"      => $userInfo['id'],"create_time"  => $date,"update_time"  => $date,];if (!empty($value[0])) {$achievementData['sn'] = trim($value[0]);}$achiveId = $this->orderAchievement->insertGetId($achievementData);$orderInputData = [];$orderData = ['source'   => $source,'project_source_detail_id'   => $project_source_detail_id,'terminal' => '报价','type'     => '报价','nature'   => '报价','text'     => '报价','nitprice' => $value[4],'workload' => 1,'status'   => 1, #1:报价'create_time' => $date,'update_time' => $date,];$orderId = $this->orderModel->insertGetId($orderData);$orderInputData = ['num'          => 1,'project'      => $project_name_id,'order_time'   => $d5,'personnel'    => $userInfo['id'],'order'        => $orderId,'depargroup'   => $depargroup,'type'         => 1, #1:报价'designer_uid' => $designer_uid,'order_achievement_id' => $achiveId,'create_time' => $date,'update_time' => $date,];$this->orderInputModel->insertGetId($orderInputData);$this->newLog('导入报价类');}Db::commit();} catch (\Exception $e) {// 回滚事务Db::rollback();throw new \Exception('导入失败');return printMsg(self::myx_code + 10, "导入失败:" . $e->getMessage());}return printMsg(0, "导入成功");}private function isDate($str) {$pattern = '/^\d{4}-\d{2}-\d{2}$/'; // 使用正则表达式匹配 YYYY-MM-DD 格式的日期if (preg_match($pattern, $str)) {return true;} else {return false;}}private function isDate2($str) {$pattern = '/^\d{4}\d{2}$/'; // 使用正则表达式匹配 YYYY-MM-DD 格式的日期if (preg_match($pattern, $str)) {return true;} else {return false;}}

excel模版文件
在这里插入图片描述

2.批量导出

public function download(Request $request){/*$authority = $this->getUserAuthority('order_input', 'download');if ($authority['code'] != 0) {return json($authority);}$res = controller('OrderAchievement')->index($request, true);*///return printMsg(0, "成功", $res);$order = OrderModel::where('source', '腾讯游戏')->where('status', '0')->select()->toArray();$title = [];foreach ($order as $k => $v) {if (empty($title[$v['terminal']])) {$title[$v['terminal']] = [$v['nature'] => [$v['type'] => [$v['text']]]];} else {if (empty($title[$v['terminal']][$v['nature']])) {$title[$v['terminal']][$v['nature']] = [$v['type'] => [$v['text']]];} else {if (empty($title[$v['terminal']][$v['nature']][$v['type']])) {$title[$v['terminal']][$v['nature']][$v['type']] = [$v['text']];} else {$title[$v['terminal']][$v['nature']][$v['type']][] = $v['text'];}}}}//return printMsg(0, "成功", $title);//die();$fileName = "需求订单";require_once './../extend/PHPExcel/IOFactory.php';require_once './../extend/PHPExcel/PHPExcel.php';$obj = new \PHPExcel();// 设置当前sheet$obj->setActiveSheetIndex(0);// 设置当前sheet的名称$obj->getActiveSheet()->setTitle('需求订单');// 列标$cellKey = ['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'];foreach (['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'] as $k => $v) {foreach (['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'] as $sk => $sv) {$cellKey[] = $v . $sv;}}//处理表头标题//$obj->getActiveSheet()->mergeCells('A1:' . $cellKey[(count($title) - 1) + 4] . '1');//合并单元格(如果要拆分单元格是需要先合并再拆分的,否则程序会报错)$obj->setActiveSheetIndex(0)->setCellValue('A1', '需求订单列表(仅腾讯需求)');$obj->getActiveSheet()->getStyle('A1')->getFont()->setBold(true);$obj->getActiveSheet()->getStyle('A1')->getFont()->setSize(11);$obj->getActiveSheet()->getStyle('A1')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);$obj->getActiveSheet()->getStyle('A1')->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER);$leftNumber = 4; //左边位移数量// 填充表头$obj->getActiveSheet()->setCellValue('A2', '来源')->setCellValue('B2', '单号')->setCellValue('C2', '项目名称')->setCellValue('D2', '类型');//合并单元格$obj->getActiveSheet()->mergeCells('A2:A5');$obj->getActiveSheet()->mergeCells('B2:B5');$obj->getActiveSheet()->mergeCells('C2:C5');$obj->getActiveSheet()->mergeCells('D2:D5');//居中$obj->getActiveSheet()->getStyle('A2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER)->getActiveSheet()->getStyle('B2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER)->getActiveSheet()->getStyle('C2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER)->getActiveSheet()->getStyle('D2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);$obj->getActiveSheet()->getStyle('A2')->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER)->getActiveSheet()->getStyle('B2')->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER)->getActiveSheet()->getStyle('C2')->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER)->getActiveSheet()->getStyle('D2')->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER);$i = 0;foreach ($title as $k => $v) {$obj->getActiveSheet()->setCellValue(($cellKey[$i + $leftNumber]) . '2', $k);$obj->getActiveSheet()->getStyle(($cellKey[$i + $leftNumber]) . '2')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);$i2 = $i;foreach ($title[$k] as $kj => $vj) {$i3 = $i;$obj->getActiveSheet()->setCellValue(($cellKey[$i + $leftNumber]) . '3', $kj);$obj->getActiveSheet()->getStyle(($cellKey[$i + $leftNumber]) . '3')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);foreach ($title[$k][$kj] as $skj => $svj) {$i4 = $i;$obj->getActiveSheet()->setCellValue(($cellKey[$i + $leftNumber]) . '4', $skj);$obj->getActiveSheet()->getStyle(($cellKey[$i + $leftNumber]) . '4')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);foreach ($svj as $ik => $iv) {$obj->getActiveSheet()->setCellValue(($cellKey[$i + $leftNumber]) . '5', $iv);$obj->getActiveSheet()->getStyle(($cellKey[$i + $leftNumber]) . '5')->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);$i++;}$obj->getActiveSheet()->mergeCells(($cellKey[$i4 + $leftNumber]) . '4' . ':' . ($cellKey[$i + 3]) . '4');}$obj->getActiveSheet()->mergeCells(($cellKey[$i3 + $leftNumber]) . '3' . ':' . ($cellKey[$i + 3]) . '3');}$obj->getActiveSheet()->mergeCells(($cellKey[$i2 + $leftNumber]) . '2' . ':' . ($cellKey[$i + 3]) . '2');}$obj->getActiveSheet()->mergeCells('A1:' . $cellKey[$i + 4] . '1');/*$obj->getActiveSheet()->mergeCells('A2:A3');$obj->getActiveSheet()->mergeCells('B3:B3');$obj->getActiveSheet()->mergeCells('C3:C3');$obj->getActiveSheet()->mergeCells('D3:D3');$obj->getActiveSheet()->mergeCells('E2:G2');$obj->getActiveSheet()->mergeCells('H2:J2');$obj->getActiveSheet()->setCellValue('E3', '首页')->setCellValue('F3', '内页')->setCellValue('G3', '排版')->setCellValue('H3', '首页')->setCellValue('I3', '内页')->setCellValue('J3', '排版');*/// 导出ob_clean();header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');header('Content-Disposition: attachment;filename="' . $fileName . '.xlsx');header('Cache-Control: max-age=1');$objWriter = \IOFactory::createWriter($obj, 'Excel2007');$objWriter->save('php://output');}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/700610.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

开发技术-Java 获取集合中元素下标并移动至指定位置

1. 说明 某些业务需要特定的元素在列表的最后或者指定位置展示。 2. 代码 import lombok.AllArgsConstructor; import lombok.Data;import java.util.*; import java.util.stream.Collectors; import java.util.stream.IntStream;Data AllArgsConstructor class Student {St…

CMNet:Contrastive Magnification Network for Micro-Expression Recognition 阅读笔记

AAAI 2023的一篇文章,东南大学几位老师的工作,用于做微表情识别中的运动增强工作, 以下是阅读时记录的笔记。 摘要: However,existing magnification strategies tend to use the features offacial images that include not onl…

喝多少瓶汽水

喝多少瓶汽水 题目描述:解法思路:解法代码:运行结果: 题目描述: 水已知1瓶汽水1元,2个空瓶可以换⼀瓶汽水,输入整数n(n>0),表示n元钱,计算可以多少汽水&a…

【Vuforia+Unity】AR06-空间环境识别功能(AreaTargets)

Vuforia原理:把被识别的物体转成图、立体图、柱形图,3D模型、环境模型,然后模型生成Vuforia数据库-导入Unity-参考模型位置开始摆放数字内容,然后参考模型自动隐藏-发布APP-识别生活中实物-数字内容叠加上去! 不论你是否曾有过相关经验,只要跟随本文的步骤,你就可以成功…

mybatis-plus 基础使用

1、mybatis-plus 简介 MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 2、特性 1)、无侵入&#xff1a…

Nginx知识笔记

一、前言 首先,我们来看一张关于正向代理和反向代理的图片 简单理解正向代理和反向代理的概念: 正向代理:在客户端配置代理服务器(和跳板机功能类似,比如公司很多机器需要通过跳板机才允许登录,正向代理的典型用途是…

【MySQL】数据类型——MySQL的数据类型分类、数值类型、小数类型、字符串类型

文章目录 MySQL数据类型1. 数值类型1.1 tinyint类型1.2 bit类型1.3 小数类型1.3.1 float1.3.2 decimal 2.字符串类型2.1 char2.2 varchar2.3 char和varchar比较2.4 日期和时间类型2.5 enum和set MySQL 数据类型 MySQL 是一个流行的开源关系型数据库管理系统。它支持多种数据类型…

数字滚动实现

介绍 vue-countup-v3 插件是一个基于 Vue3 的数字动画插件,用于在网站或应用程序中创建带有数字动画效果的计数器。通过该插件,我们可以轻松地实现数字的递增或递减动画,并自定义其样式和动画效果。该插件可以用于许多场景,例如展…

展锐S8000安卓核心板参数_紫光展锐5G核心板模块定制方案

展锐S8000核心板模块是基于八核S8000平台开发设计的,采用了先进的6nm EUV制程技术。搭载了全新的智能Android 13操作系统,展现出超强的画面解析能力和高性能双通道MIPI,拥有120Hz高刷新率,独立NPU和3.2TOPS Al算力,同时…

【机器学习】特征工程之特征选择

🎈个人主页:豌豆射手^ 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:机器学习 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进…

数字化转型导师坚鹏:政府数字化流程管理

政府数字化流程管理 课程背景: 很多政府存在以下问题: 不清楚数字化对流程有什么影响? 不知道政府业流程如何进行优化? 不知道政府业流程优化的具体案例? 课程特色: 有实战案例 有原创观点 …

【README 小技巧】在项目README.md 中展示发布到maven 仓库版本

在项目README.md 中展示发不到nexus 的快照版本 <p align"center"><a target"_blank" href"https://search.maven.org/search?qwu-lazy-cloud-network%20wu-lazy-cloud-network"><img src"https://img-home.csdnimg.cn/ima…

【最新Dubbo3深入理解】Dubbo3源码中的一些小技巧

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

“点击查看显示全文”遇到的超链接默认访问的问题

今天在做一个例子&#xff0c;就是很常见的点击展开全文。 我觉得这是一个很简单的效果&#xff0c;也就几行代码的事&#xff0c;结果点击了以后立刻隐藏不见&#xff0c;控制台代码也不报错&#xff0c;耽误了我很长时间&#xff0c;最后才发现问题出在超链接身上。 “展开全…

太阳能光伏电池模型参数辨识模型介绍

一、太阳能光伏电池模型参数辨识模型介绍 由于传统化石能源短缺问题日益严重&#xff0c;我国对新能源发展的重视提到了前所未有的高度。太阳能作为一种可再生能源&#xff0c;不会对环境造成污染&#xff0c;受到了越来越多的关注太阳能由于其储量丰富,无污染和无地域限制等优…

Clickhouse系列之连接工具连接、数据类型和数据库

基本操作 一、使用连接工具连接二、数据类型1、数字类型IntFloatDecimal 2、字符串类型StringFixedStringUUID 3、时间类型DateTimeDateTime64Date 4、复合类型ArrayEnum 5、特殊类型Nullable 三、数据库 一、使用连接工具连接 上一篇介绍了clickhouse的命令行登录&#xff0c…

【大厂AI课学习笔记NO.52】2.3深度学习开发任务实例(5)需求采集考虑维度

今天来学习&#xff0c;怎么做需求分析&#xff0c;如何明确数据采集需求。 我把自己考试通过的学习笔记&#xff0c;都分享到这里了&#xff0c;另外还有一个比较全的思维脑图&#xff0c;我导出为JPG文件了。下载地址在这里&#xff1a;https://download.csdn.net/download/g…

软件设计师软考题目解析02 --每日五题

想说的话&#xff1a;要准备软考了。0.0&#xff0c;其实我是不想考的&#xff0c;但是吧&#xff0c;由于本人已经学完所有知识了&#xff0c;只是被学校的课程给锁在那里了&#xff0c;不然早找工作去了。寻思着反正也无聊&#xff0c;就考个证玩玩。 本人github地址&#xf…

C++之std::async

std::async是C提供的一个异步处理函数。 函数原型&#xff1a; template<typename _Fn, typename... _Args> future<__async_result_of<_Fn, _Args...>> async(launch __policy, _Fn&& __fn, _Args&&... __args); 参数说明: int thFun(in…

MT8791迅鲲900T联发科5G安卓核心板规格参数_MTK平台方案定制

MT8791安卓核心板是一款搭载了旗舰级配置的中端手机芯片。该核心板采用了八核CPU架构设计&#xff0c;但是升级了旗舰级的Arm Cortex-A78核心&#xff0c;两个大核主频最高可达2.4GHz。配备了Arm Mali-G68 GPU&#xff0c;通过Mali-G88的先进技术&#xff0c;图形处理性能大幅提…