PHP与Excel 笔记
二: PHPExcel: Github上可以下载此插件包,用法如下:
前端:
//上传阅卷员Excel文件 $("#upload_member").click(function (e) { e.preventDefault(); var members_form = document.getElementById("members_form"); var formData = new FormData(members_form); $.ajax({ url: "/marking_manage/ajax_upload_members", method: "post", data: formData, dataType: "JSON", success: function (data) { //这里显示php脚本读取excel文件处理后返回的值 }, //jquery使用FormData时必须设置下面两项,否则不会成功 processData: false, // 不处理数据 contentType: false // 不设置内容类型 }) }); //下载导入阅卷员模板 $("#download_excel").click(function (e) { self.location.href = "/marking_manage/ajax_download_members" });
后端:
public function ajax_upload_members() { require_once(APPPATH . 'libraries/PHPExcel.php'); require_once(APPPATH . 'libraries/PHPExcel/IOFactory.php'); date_default_timezone_set("PRC"); $file = $_FILES; $fileName = $file['members']["tmp_name"]; $inputFileType = PHPExcel_IOFactory::identify($fileName); $objReader = PHPExcel_IOFactory::createReader($inputFileType); $objPHPExcel = $objReader->load($fileName); // 确定要读取的sheet $sheet = $objPHPExcel->getSheet(0); $highestRow = $sheet->getHighestRow(); //读取帐号 $accounts = array();//保存文件中的所有帐号,实际就是A列中的所有以t开头的帐号 for ($row = 1; $row <= $highestRow; $row++) { $rowData = $sheet->rangeToArray('A' . $row . ':' . "A" . $row); $account = strtolower($rowData[0][0]); if (preg_match("/^t\d+/", $account)) { $accounts[] = $account; } } $accounts = array_unique($accounts); //过滤帐号并返回 $this->load->model("school_admin_model"); $retval = array();//返回值 foreach ($accounts as $account) { $teacher_info = $this->school_admin_model->get_admin_by_where(array("account"=>$account)); // $retval[$teacher_info["school_id"]][] = array("account"=>$teacher_info["account"], "teacher_name"=>$teacher_info['teacher_name']); $retval[$teacher_info["school_id"]][] = $teacher_info["id"]; } dexit($retval); } //下载阅卷员模板 public function ajax_download_members() { require_once(APPPATH . 'libraries/PHPExcel.php'); require_once(APPPATH . 'libraries/PHPExcel/IOFactory.php'); date_default_timezone_set("PRC"); $objPHPExcel = new PHPExcel(); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A1', '帐号') ->setCellValue('B1', '姓名') ->setCellValue('C1', '学校'); // 设置第一个sheet为工作的sheet $objPHPExcel->setActiveSheetIndex(0); // 保存Excel 2007格式文件 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');//如果第二个参数是"Excel5"则生成2003版本的excel文件 browser_export('xxx','browser_excel07.xls');//输出到浏览器 $objWriter->save('php://output'); } function browser_export($type, $filename) { if ($type == "Excel5") { header('Content-Type: application/vnd.ms-excel');//告诉浏览器将要输出excel03文件 } else { header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');//告诉浏览器数据excel07文件 } header('Content-Disposition: attachment;filename="' . $filename . '"');//告诉浏览器将输出文件的名称 header('Cache-Control: max-age=0');//禁止缓存 }
PHP与Excel 笔记的更多相关文章
- Excel 笔记目录
前言 Excel 是微软(Microsoft)公司推出的 Office 办公系列软件的一个重要组成部分,主要用于电子表格处理,可以高效地完成各种表格和图表的设计,进行复杂的数据计算和分析. 一句科普 ...
- 【JAVA】使用Aphache poi操作EXCEL 笔记
1 下载poi,地址 http://poi.apache.org/ 选择3.9版本. 2 刚开始尝试 把poi.jar放在D:\Program Files\java\jdk1.6.0_20\lib(不 ...
- .NET操作Excel笔记
如果你新建一个项目的话,首先要添加Microsoft.Office.Core 与Microsoft.Office.Interop.Exce这两个应用,然后就能很方便的操作了,示例代码(只实现了简单的读 ...
- 【PYTHON】操作excel笔记
import xlrd book = xlrd.open_workbook('..//data//case1.xls') # 获取excel对象 print(book.sheets()) # 获取ex ...
- excel笔记
提取单元格中的数字部分 =MID(LOOKUP(1,-(1&MID(A1,MIN(FIND({0;1;2;3;4;5;6;7;8;9},A1&1/17)),ROW($1:$15)))) ...
- 王佩丰第一讲 认识excel笔记
改变工作表表浅颜色 批量插入工作表 选择多张工作表然后插入 找到表格边界区域快捷键(找到表格的最后一行):快速到达最上下左右端 点击边框上下左右双击 从指定的位置开始冻结窗格 输入今天的日期 快捷键c ...
- excel 笔记
1.复制公式到整列(至文件尾): 当你想复制公式到整列(至文件尾)可选中有公式的单元格,待出现黑色填充柄时,双击即可
- Dynamic CRM 2013学习笔记(三十一)自定义用excel批量导入实体数据
有一个实体的子表数据量太大,于是客户想用execel来导入实体数据.首先想到的是用系统自带的Import Data,客户嫌太麻烦,比如lookup字段要做map等. 下面是具体的实现步骤: 一.定义e ...
- VSTO学习笔记(十四)Excel数据透视表与PowerPivot
原文:VSTO学习笔记(十四)Excel数据透视表与PowerPivot 近期公司内部在做一种通用查询报表,方便人力资源分析.统计数据.由于之前公司系统中有一个类似的查询使用Excel数据透视表完成的 ...
随机推荐
- 基于IAR平台FreeRTOS移植
开始这篇文章之前先简单说明一下,我使用的MCU是我们公司自主研发的ACH1180芯片,和STM32差不多,都是Cortex-M4的核,所以移植的过程参考了STM32移植的步骤. 1.解压FreeRT ...
- 爬虫之scrapy入门
1.介绍 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的 ...
- keil5一点project就闪退
进注册表“HKEY_CURRENT_USER——SOFTWARE——Keil——矿ision5——Recent Projects”里面,保留一个默认的(我是保留了,估计删掉也可以),其余 ...
- linux 安装gcc8
https://blog.csdn.net/longji/article/details/80400339 01 ubuntu1604desktop_x64 安装gcc8.1.0系统环境: gcc版本 ...
- ansible批量自动安装LNMP
- mapreduce 内存分配
稍微有点mapreduce使用经验的同学肯定对OOM不陌生,对的,我目前在mapReduce里面遇到的最多的报错也是内存分配出错,所以看到好多hadoop执行脚本里面有好多关于内存的参数,虽然是知道和 ...
- linux应用之test命令详细解析
test命令用法. 功能:检查文件和比较值 1)判断表达式 if test (表达式为真) if test !表达式为假 test 表达式1 –a 表达式2 两个表 ...
- Unity3d项目入门之Rolling Ball
下面通过分析制作一个简单的收集特定物体的滚球游戏来入门unity,包括操作面板和C#脚本的编写导入,创建Game Object和给Object添加组件等等. 一 初始设置 在Assert下创建主场景M ...
- appium 移动端自动化测试一
最近公司决定使用appium为主体框架做一个移动端得自动化测试系统,我会陆续记录项目得进展. 1.首先是appium环境得搭建, 需要安装appium-server ,appium-desktop, ...
- 关于iOS刷新UI需要在主线程执行
为什么一定要在主线程刷新UI? 安全+效率:因为UIKit框架不是线程安全的框架,当在多个线程进行UI操作,有可能出现资源抢夺,导致问题. 其实:在子线程是不能更新UI的, 看到能更新的结果只是个假象 ...