thinkphp-PHP实现Excel导入 导出功能
Excel导出
//功能:导出题库模板
public function get_contract_ex()
{
ob_get_clean();
header("Content-Typ:text/html;charset=utf-8");
vendor('Excel.PHPExcel');
vendor('Excel.PHPExcel.IOFactory');
//设定缓存模式)
$cacheMethod = \PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized;
$cacheSettings = array();
\PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings); $objPHPExcel = new \PHPExcel();
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', '题干');//设置列的值
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('B1', '选项A');//设置列的值
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('C1', '选项B');//设置列的值
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('D1', '选项C');//设置列的值
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('E1', '选项D');//设置列的值
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('F1', '答案');//设置列的值 //设置居中
$objPHPExcel->getDefaultStyle()
->getAlignment()
->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER)
->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
/*设置字段宽度*/
$objPHPExcel->getActiveSheet(0)->getColumnDimension('A')->setWidth(18);
$objPHPExcel->getActiveSheet(0)->getColumnDimension('B')->setWidth(18);
$objPHPExcel->getActiveSheet(0)->getColumnDimension('C')->setWidth(18);
$objPHPExcel->getActiveSheet(0)->getColumnDimension('D')->setWidth(18);
$objPHPExcel->getActiveSheet(0)->getColumnDimension('E')->setWidth(18);
$objPHPExcel->getActiveSheet(0)->getColumnDimension('F')->setWidth(18);
/*行高*/
$objPHPExcel->getActiveSheet(0)->getRowDimension(1)->setRowHeight(30);
$objPHPExcel->getActiveSheet(0)->getDefaultStyle()->getFont()->setName("微软雅黑");//设置默认字体大小和格式
$objPHPExcel->getActiveSheet(0)->getStyle('A1:F1')->getFont()->setBold(true); //字体加粗 //导出多条此处可加foreach循环--开始
$objPHPExcel->setActiveSheetIndex(0) //选择
//Excel的第A列,uid是你查出数组的键值,下面以此类推
->setCellValue('A2', "中国的首都是")
->setCellValue('B2', "北京")
->setCellValue('C2', "上海")
->setCellValue('D2', "广州")
->setCellValue('E2', "深圳")
->setCellValue('F2', "A");
//导出多条此处可加foreach循环--结尾
$objPHPExcel->getActiveSheet(0)->setTitle("题库模板");
/*浏览器输出*/
// $filename = "题库导入模板";
$filename = iconv("utf-8", "gb2312", "题库导入模板");
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="' . $filename . ".xlsx");
header('Cache-Control: max-age=0');
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
$objWriter->save('php://output');
}
Excel导入
html代码:
<button id="upload" type="button"> 导入数据</button> jquery代码:
$('#upload').click(function() {
ajaxFileUpload();
});
function ajaxFileUpload() {
$.ajaxFileUpload({
url: "<{:U('ServiceQuestions/upload_file')}>", //用于文件上传的服务器端请求地址
secureuri: false, //是否需要安全协议,一般设置为false
fileElementId: 'file2', //文件上传域的ID
dataType: 'text', //返回值类型 一般设置为json
success: function(data, status) //服务器成功响应处理函数
{
var str = data;
var data_array = data.split(",");
if (data_array[0] != 0) {
layer.msg(data_array[1], {
time: 1000
});
} else if (data_array[0] == 0) { //上传成功
layer.msg(data_array[1], {
time: 1000
});
}
},
error: function(data, status, e) //服务器响应失败处理函数
{
alert("网络错误");
}
})
return false;
}
后端php代码:
public function upload_file()
{
$excel_type = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
$tmp_file = $_FILES ['file-2'] ['tmp_name'];
$file_types = explode(".", $_FILES ['file-2'] ['name']);
$upload_type = $_FILES['file-2']['type'];
$file_type = $file_types [count($file_types) - 1]; if ($file_type != 'xlsx' and $upload_type != $excel_type) {
$res['error'] = '1';
$res['msg'] = '不是Excel文件,请重新上传';
echo implode($res, ',');
exit;
} else {
//上传文件
$upload_info = $this->uploadOne('tesques'); if (!$upload_info) {
$res['error'] = '1';
$res['msg'] = '上传失败,请刷新重试!';
echo implode($res, ',');
exit; } else {
//导入题库
$result = $this->import_contract($upload_info);
if ($result) {
unlink('./Upload/' . $upload_info);
$res['error'] = '0';
$res['msg'] = '上传成功!'; } else {
$res['error'] = '1';
$res['msg'] = '上传失败,请确认数据格式是否正确!';
}
echo implode($res, ',');
exit; }
}
} /**
* 单文件上传
* @return [type] [description]
*/
public function uploadOne($dir)
{
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728;// 设置附件上传大小
$upload->exts = array('xlsx');// 设置附件上传类型
$upload->rootPath = './Upload/'; // 设置附件上传根目录
$upload->savePath = $dir . '/'; // 设置附件上传根目录 $upload->autoSub = TRUE; //是否自动生成二级子目录
$upload->subName = array('date', 'Ymd'); //子目录规则 // 上传单个文件
$info = $upload->uploadOne($_FILES['file-2']); if (!$info) {// 上传错误提示错误信息
return false;
} else {// 上传成功 获取上传文件信息
return $info['savepath'] . $info['savename'];
}
} /**
* Excel导入数据库表
* @return [type] [description]
*/
public function import_contract($filedir)
{
ob_get_clean();
vendor('Excel.PHPExcel');
vendor('Excel.PHPExcel.IOFactory');
vendor('Excel.PHPExcel.IReader');
$objReader = \PHPExcel_IOFactory::createReader('Excel2007');//use excel2007 for 2007 format
$objPHPExcel = $objReader->load('./Upload/' . $filedir); //$filename指定的文件
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); // 取得总行数
$highestColumn = $sheet->getHighestColumn(); // 取得总列数
// $sheetCount = $objPHPExcel->getSheetCount();//获取总的sheet数
$data = array();
$now_time = time(); //获取文件中的数据
// $datas = $objPHPExcel->getSheet(0)->toArray();//以数组的形式获取第一个sheet页的数据。与两个for循环的功能相同。
for ($rowIndex = 2; $rowIndex <= $highestRow; $rowIndex++) { //循环行
for ($colIndex = 'A'; $colIndex <= $highestColumn; $colIndex++) { //循环列
$addr = $colIndex . $rowIndex;
$cell = $objPHPExcel->getActiveSheet()->getCell($addr)->getValue();//获取某行某列的值
if ($cell instanceof \PHPExcel_RichText) { //富文本转换字符串
$cell = $cell->__toString();
}
$data[$rowIndex][] = $cell;
}
$data[$rowIndex][] = $now_time;
$datas[] = $data[$rowIndex];
}
// array_shift($datas); //删除第一个元素
if ($datas) {
foreach ($datas as $key => $value) {
$add_data['qustion_title'] = $value[0]; //题目内容
$add_data['state'] = $value[5]; // 正确答案
$add_data['create_time'] = $value[6]; //添加时间
$filter_datas = array_filter($add_data, array($this, 'filter_recontreact')); //判断数据是否有null值
if (count($filter_datas)) {
$test = M('test_cont');
$test->startTrans();
$res = $test->add($add_data);
if ($res) {
$test->commit();
//选项A
$add_data2['0']['test_id'] = $res; //所属题目ID
$add_data2['0']['answer_name'] = $value[1]; // 答案内容
$add_data2['0']['create_time'] = $value[6]; //添加时间
$add_data2['0']['state'] = "A"; //
//选项B
$add_data2['1']['test_id'] = $res; //所属题目ID
$add_data2['1']['answer_name'] = $value[2]; // 答案内容
$add_data2['1']['create_time'] = $value[6]; //添加时间
$add_data2['1']['state'] = "B"; //ABCD
//选项C
$add_data2['2']['test_id'] = $res; //所属题目ID
$add_data2['2']['answer_name'] = $value[3]; // 答案内容
$add_data2['2']['create_time'] = $value[6]; //添加时间
$add_data2['2']['state'] = "C"; //ABCD
//选项D
$add_data2['3']['test_id'] = $res; //所属题目ID
$add_data2['3']['answer_name'] = $value[4]; // 答案内容
$add_data2['3']['create_time'] = $value[6]; //添加时间
$add_data2['3']['state'] = "D"; //ABCD
$filter_datas2 = array_filter($add_data2, array($this, 'filter_recontreact')); //判断数据是否有null值
if (count($filter_datas2)) {
$res2 = M('test_answer')->addAll($add_data2);
if (!$res2) {
$test->rollback();
return false;
}
} else {
return false;
}
} else {
$test->rollback();
return false;
}
} else {
return false;
}
}
return 1;
} else {
return false;
}
}
thinkphp-PHP实现Excel导入 导出功能的更多相关文章
- ASP.NET 之 常用类、方法的超级总结,并包含动态的EXCEL导入导出功能,奉上类库源码
实用类:UtilityClass 包含如下方法 判断对象是否为空或NULL,如果是空或NULL返回true,否则返回false 验证手机号是否正确 13,15,18 验证邮箱 验证网址 MD5加密,返 ...
- 实现excel导入导出功能,excel导入数据到页面中,页面数据导出生成excel文件
今天接到项目中的一个功能,要实现excel的导入,导出功能.这个看起来思路比较清楚,但是做起了就遇到了不少问题. 不过核心的问题,大家也不会遇到了.每个项目前台页面,以及数据填充方式都不一样,不过大多 ...
- 基于 POI 封装 ExcelUtil 精简的 Excel 导入导出
注 本文是使用 org.apache.poi 进行一次简单的封装,适用于大部分 excel 导入导出功能.过程中可能会用到反射,如若有对于性能有极致强迫症的同学,看看就好. 序 由于 poi 本身只是 ...
- 企业级自定义表单引擎解决方案(十六)--Excel导入导出
Excel对于后端管理系统来说,永远都是绕不开的话题,开发Excel导入导出功能往往都比较麻烦,因为涉及到Excel导入模板制作.Excel表格数据与系统数据库表字段映射.Excel导入数据验证.验证 ...
- Laravel Excel 实现 Excel-CSV 文件导入导出功能
Laravel Excel 是一款基于 PHPExcel 开发的Laravel框架专用的 Excel/CSV 文件导入导出功能的扩展包,用起来的非常方便. 它的 Github 地址是:https:// ...
- Laravel 5 中使用 Laravel Excel 实现 Excel/CSV 文件导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和导出. 该 ...
- 在 Laravel 5 中使用 Laravel Excel 实现 Excel/CSV 文件导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel ,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和 导出 ...
- laravel框架excel 的导入导出功能
1.简介 Laravel Excel 在 Laravel 5 中集成 PHPOffice 套件中的 PHPExcel,从而方便我们以优雅的.富有表现力的代码实现Excel/CSV文件的导入和导出. ...
- poi实现excel的导入导出功能
Java使用poi实现excel的导入导出功能: 工具类ExcelUtil,用于解析和初始化excel的数据:代码如下 package com.raycloud.kmmp.item.service.u ...
随机推荐
- HDU 4143 A Simple Problem 分解因式
求一个最小的正整数x,使得(y + x) (y - x) = n成立 考虑一下n的分解因式. 可能会想到枚举n的约数,那么a * b = n成立,取最小的x即可 但是要枚举到n / 2,这样会超时. ...
- js执行上下文和执行栈
执行上下文就是JavaScript 在被解析和运行时环境的抽象概念,JavaScript 运行任何代码都是在执行上下文环境中运行的,执行上下文包括三个周期:创建——运行——销毁,重点说一下创建环节. ...
- Zipkin — 微服务链路跟踪.
一.Zipkin 介绍 Zipkin 是什么? Zipkin的官方介绍:https://zipkin.apache.org/ Zipkin是一款开源的分布式实时数据追踪系统(Distributed ...
- pygame 使用
模块概况 display image event key mouse font 类概况 Rect: 返回的矩阵区域(图片) Surface: 可以看做是一个贴图, 它就是来显示的 display(与显 ...
- elasticsearch报错:None of the configured nodes are available: []
问题:在内网测试的时候可以正常访问,但是部署到外网上客户端连接elasticsearch报错:None of the configured nodes are available: [] 原因:默认情 ...
- webapp一些样式记录
图片外面的div设置宽高自适应width: 100vw; max-width: 640px; display: block; height: 43.75vw; max-height: 280px; f ...
- 【干货】JavaScript DOM编程艺术学习笔记4-6
四.案例研究:JavaScript图片库 js: function showPic(whichpic){ //取得链接 var source=whichpic.getAttribute("h ...
- Android商城开发系列(十三)—— 首页热卖商品布局实现
热卖商品布局效果如下图: 这个布局跟我们上节做的推荐是一样的,也是用LinearLayout和GridView去实现的,新建一个hot_item.xml,代码如下所示: <?xml versio ...
- linux 命令——35 ln(转)
ln 是linux中又一个非常重要命令,它的功能是为某一个文件在另外一个位置建立一个同步的链接.当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要 ...
- OpenGL glReadPixels 转成 CImage
本来是一件很简单的事情,就是将View上使用OpenGL画出来的数据生成图片让其实现打印的功能,我们知道MFC提供打印的接口是不支持OpenGL的(至少我不清楚),必须将它转成GDI再画在Print的 ...