thinkPHP的Excel插件
原文地址 http://www.thinkphp.cn/topic/14005.html
总结的注意事项
1实例化第三方类,要在类名前加\ ,不然引用地址不对.
实现步骤:
一:在http://phpexcel.codeplex.com/下载最新PHPExcel放到Vendor下,注意位置:ThinkPHP\Extend\Vendor\PHPExcel\PHPExcel.php。
二:导出excel代码实现
- /**方法**/
- function index(){
- $this->display();
- }
- public function exportExcel($expTitle,$expCellName,$expTableData){
- $xlsTitle = iconv('utf-8', 'gb2312', $expTitle);//文件名称
- $fileName = $_SESSION['account'].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
- $xlsName = "User";
- $xlsCell = array(
- array('id','账号序列'),
- array('truename','名字'),
- array('sex','性别'),
- array('res_id','院系'),
- array('sp_id','专业'),
- array('class','班级'),
- array('year','毕业时间'),
- array('city','所在地'),
- array('company','单位'),
- array('zhicheng','职称'),
- array('zhiwu','职务'),
- array('jibie','级别'),
- array('tel','电话'),
- array('qq','qq'),
- array('email','邮箱'),
- array('honor','荣誉'),
- array('remark','备注')
- );
- $xlsModel = M('Member');
- $xlsData = $xlsModel->Field('id,truename,sex,res_id,sp_id,class,year,city,company,zhicheng,zhiwu,jibie,tel,qq,email,honor,remark')->select();
- foreach ($xlsData as $k => $v)
- {
- $xlsData[$k]['sex']=$v['sex']==1?'男':'女';
- }
- $this->exportExcel($xlsName,$xlsCell,$xlsData);
- }
第三:导入excel数据代码
- function impUser(){
- if (!empty($_FILES)) {
- import("@.ORG.UploadFile");
- $config=array(
- 'allowExts'=>array('xlsx','xls'),
- 'savePath'=>'./Public/upload/',
- 'saveRule'=>'time',
- );
- $upload = new UploadFile($config);
- if (!$upload->upload()) {
- $this->error($upload->getErrorMsg());
- } else {
- $info = $upload->getUploadFileInfo();
- }
- 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(); // 取得总列数
- for($i=3;$i<=$highestRow;$i++)
- {
- $data['account']= $data['truename'] = $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue();
- $sex = $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue();
- // $data['res_id'] = $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue();
- $data['class'] = $objPHPExcel->getActiveSheet()->getCell("E".$i)->getValue();
- $data['year'] = $objPHPExcel->getActiveSheet()->getCell("F".$i)->getValue();
- $data['city']= $objPHPExcel->getActiveSheet()->getCell("G".$i)->getValue();
- $data['company']= $objPHPExcel->getActiveSheet()->getCell("H".$i)->getValue();
- $data['zhicheng']= $objPHPExcel->getActiveSheet()->getCell("I".$i)->getValue();
- $data['zhiwu']= $objPHPExcel->getActiveSheet()->getCell("J".$i)->getValue();
- $data['jibie']= $objPHPExcel->getActiveSheet()->getCell("K".$i)->getValue();
- $data['honor']= $objPHPExcel->getActiveSheet()->getCell("L".$i)->getValue();
- $data['tel']= $objPHPExcel->getActiveSheet()->getCell("M".$i)->getValue();
- $data['qq']= $objPHPExcel->getActiveSheet()->getCell("N".$i)->getValue();
- $data['email']= $objPHPExcel->getActiveSheet()->getCell("O".$i)->getValue();
- $data['remark']= $objPHPExcel->getActiveSheet()->getCell("P".$i)->getValue();
- $data['sex']=$sex=='男'?1:0;
- $data['res_id'] =1;
- $data['last_login_time']=0;
- $data['create_time']=$data['last_login_ip']=$_SERVER['REMOTE_ADDR'];
- $data['login_count']=0;
- $data['join']=0;
- $data['avatar']='';
- $data['password']=md5('123456');
- M('Member')->add($data);
- }
- $this->success('导入成功!');
- }else
- {
- $this->error("请选择上传的文件");
- }
- }
四、模板代码
- <html>
- <head>
- </head>
- <body>
- <P><a href="{:U('Index/expUser')}" >导出数据并生成excel</a></P><br/>
- <form action="{:U('Index/impUser')}" method="post" enctype="multipart/form-data">
- <input type="file" name="import"/>
- <input type="hidden" name="table" value="tablename"/>
- <input type="submit" value="导入"/>
- </form>
- </body>
- </html>
thinkPHP的Excel插件的更多相关文章
- php 和thinkphp 对excel操作
php对excel的操作主要通过引入 excel_reader2.php 或者是PHPExcel 类进行 两个文件自行下载 php 对其读操作: 文件目录结构 excel_reader2.php ...
- 免费高端出辕营,横空出世惊鬼神 Excel插件:ExcelPower_Helper 0.41初出茅庐
免费高端出辕营,横空出世惊鬼神 Excel插件:ExcelPower_Helper 0.41初出茅庐 隐鹤 倾心开发 2019.4.1 1. 引言 经过前后大约零零散散的一年的开发, ...
- 【小o地图Excel插件版】计算两点间驾车路径,获取途径道路、驾车距离、耗时等信息
小o地图Excel插件版:一款基于Excel软件开发的地图软件,提供基于Excel表格进行地理数据挖掘.地理数据分析.地图绘制.地图图表等功能的工具类软件.具有易用.高效.稳定的特点,能够满足地理数据 ...
- 【小o地图Excel插件版】不止能做图表,还能抓58、大众点评网页数据...
小o地图Excel插件版:一款基于Excel软件开发的地图软件,提供基于Excel表格进行地理数据挖掘.地理数据分析.地图绘制.地图图表等功能的工具类软件.具有易用.高效.稳定的特点,能够满足地理数据 ...
- 适用于iview的表格转Excel插件
在网上找的一个表格转excel插件,经过修改后使其适用于iview中的table组件 let idTmr; const getExplorer = () => { let explorer = ...
- 导出Excel插件——Export-CSV ---20150610
出处:http://bbs.hcharts.cn/thread-99-1-1.html 导出Excel插件——Export-CSV 一.插件信息 插件名:Export-CSV(导出Execl文件) ...
- 个人用户永久免费,可自动升级版Excel插件,使用VSTO开发,Excel催化剂安装过程详解及安装失败解决方法
因Excel催化剂用了VSTO的开发技术,并且为了最好的用户体验,用了Clickonce的布署方式(无需人工干预自动更新,让用户使用如浏览器访问网站一般,永远是最新的内容和功能).对安装过程有一定的难 ...
- django入门8之xadmin引入富文本和excel插件
django入门8之xadmin引入富文本和excel插件 Xadmin引入富文本 插件的文档 https://xadmin.readthedocs.io/en/docs-chinese/make_p ...
- 修复ThinkPHP导出excel数字过大时显示为科学记数法
修复ThinkPHP导出excel数字过大时显示为科学记数法,这种显示对于查看的用户来说是及其不友好的.所以,我们要使其转化为正常的数字串! 我在google 的过程中,查了一些资料.其中 1).// ...
随机推荐
- Gradle学习总结——抓重点学Gradle
前言 网上关于Gradle的教程很多,但很多都是以"面"切入- 通过大量讲解其用法及其API分类来阐述.但Gradle API使用技巧众多,API更是成千上百,臣妾记不住呀.个人深 ...
- Mysql和网络连接相关的参数介绍
摘要:同时还需要注意OS级别的网络监听队列的限制.因为如果OS的网络监听设置小于mysql的back_log设置的时候,我们加大back_log是没有意义的... max_conecctions:整个 ...
- PatentTips - Optimizing power usage by factoring processor architectural events to PMU
BACKGROUND Processor power consumption has become a major issue in recent years. The current trend o ...
- PuTTY介绍、安装、使用
简介 PuTTY是一个Telnet.SSH.rlogin.纯TCP以及串行接口连接软件.较早的版本仅支持Windows平台,在最近的版本中开始支持各类Unix平台,并打算移植至Mac OS X上.除了 ...
- lua 中string字符串的使用(string.len, string.char)
table.keys 返回指定表格中的全部键. 格式: keys = table.keys(表格对象) 使用方法演示样例: local t = {a = 1, b = 2, c = 3} local ...
- Gym 100418J Lucky tickets(数位dp)
题意:给定一个n.求区间[1, n]之间的全部的a的个数.a满足: a能整除 把a表示自身二进制以后1的个数 思路:题意非常绕.... 数位dp,对于全部可能的1的个数我们都dfs一次 对于某一个可 ...
- void型指针
void型指针,表示这个指针指向的内存中的数据的类型要由用户来指定. 比方内存分配函数malloc函数返回的指针就是void *型. 用户在使用这个指针的时候.要进行强制类型转换,也就是显式说明该指针 ...
- Android应用之——微信微博第三方sdk登录分享使用过程中的一些常见问题
前言 近期在使用第三方登录和分享的过程中遇到了非常多问题,一方面能够归结为自己经验的不足,还有一方面事实上也说明了官方文档的含糊不清.这篇博文不会写关于怎样使用第三方登录分享,由于官方文档已经写明了步 ...
- HDOJ 题目3518 Boring counting(后缀数组,求不重叠反复次数最少为2的子串种类数)
Boring counting Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- TOMCAT虚拟路径配置
在tomcat安装好后,只要把你的web项目copy到%TOMCAT_HOME%webapp下面就可以是使用啦!!其实还有种方法就是设定虚拟目录,即把项目的目录映射到tomcat中.这样做即可以不用重 ...