[PHP]代码
set_time_limit(0);//防止数据量过大超时 //处理进程 import('ORG.Net.UploadFile'); $upload = new UploadFile(); // 实例化上传类 $upload->maxSize = 4 * 1024 * 1024; // 设置附件上传大小 $upload->allowExts = array('xls'); $upload->savePath = './Upload/data/'; // 设置附件上传目录 $upload->saveRule = date('YmdHis'); if (!$upload->upload()) { // 上传错误提示错误信息 echo $upload->getErrorMsg(); } else { //进行异常捕获,防止导入错误 try{ //导入完成,开始数据处理流程 $info = $upload->getUploadFileInfo(); $data = $info[0]; $path = $data['savepath'].$data['savename']; /** * 开始Excel处理进程 */ vendor('PHPExcel.PHPExcel'); $objReader = new PHPExcel_Reader_Excel5(); $objExcel = $objReader->load($path); $objSheet = $objExcel->getActiveSheet(); $rows = $objSheet->getHighestRow();//行数 /** * 单元格定义 * B 二级学科代码 * C 二级学科名称 * D 一级学科代码 * E 一级学科名称 * F 学院代码 * G 学院名称 */ //定义数组 $second_discipline_code = array(); $second_discipline_name = array(); $first_discipline_code = array(); $first_discipline_name = array(); $college_code = array(); $college_name = array(); for($i=1;$i<=$rows;$i++){ $second_discipline_code[] = $objSheet->getCell("B$i")->getFormattedValue(); $second_discipline_name[] = $objSheet->getCell("C$i")->getFormattedValue(); $first_discipline_code[] = $objSheet->getCell("D$i")->getFormattedValue(); $first_discipline_name[] = $objSheet->getCell("E$i")->getFormattedValue(); $college_code[] = $objSheet->getCell("F$i")->getFormattedValue(); $college_name[] = $objSheet->getCell("G$i")->getFormattedValue(); } //写入数据库 $firstDataMdl = M('DataFirstDiscipline'); $secondDataMdl = M('DataSecondDiscipline'); $first_discipline_code_backup = $first_discipline_code;//不去重复的备份 $first_discipline_code = array_unique($first_discipline_code);//去重 //一级学科导入 foreach($first_discipline_code as $k=>$v){ $temp['college_id'] = $college_code[$k]; $temp['first_discipline_code'] = $v; $temp['first_discipline_name'] = $first_discipline_name[$k]; $firstDataMdl->add($temp); } //二级学科导入 foreach($second_discipline_code as $k=>$v){ $temp['second_discipline_code'] = $v; $temp['second_discipline_name'] = $second_discipline_name[$k]; //根据一级学科代码查一级学科ID $first_discipline_code_flag = $first_discipline_code_backup[$k]; $id = $firstDataMdl->where("first_discipline_code = %d",$first_discipline_code_flag)->getField('first_discipline_id'); $temp['first_discipline_id'] = $id; $secondDataMdl->add($temp); } echo '导入成功完成!'; }catch (PHPExcel_Exception $e){ echo $e->getMessage(); }catch (ThinkException $e){ echo $e->getMessage(); }catch (Exception $e){ echo '程序异常,导入失败!'; } }
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章
如何修复KB5055518无法在Windows 10中安装?
1 个月前ByDDD
如何修复KB5055523无法在Windows 11中安装?
1 个月前ByDDD
<🎜>:种植花园 - 完整的突变指南
3 周前ByDDD
<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前By尊渡假赌尊渡假赌尊渡假赌
如何修复KB5055612无法在Windows 10中安装?
3 周前ByDDD

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Atom编辑器mac版下载
最流行的的开源编辑器