PHPExcel使用

一:引入

tp5.0,tp5.1:

  1:composer方式

    a:根目录下执行:composer require phpoffice/phpexcel

    b:引入(可new \PHPExcel()直接使用):

      use PHPExcel_IOFactory;

      use PHPExcel;

  2:下载引入方式

    a:下载PHPExcel:

      地址:https://pan.baidu.com/s/1gfrEt7tz2uwOrubeHcuorg

      提取码:zxcv

    b:放到项目根目录extend文件夹下,目录结构如下:

      

    c:引入(可new \PHPExcel()直接使用)

二:导出

  预置模板方式(接下方导出):

//要导出的数据

$data[] = ['aa'=>'第一列', 'bb'=>'第二列', 'cc'=>'第三列', 'dd'=>'第四列'];

$data[] = ['aa'=>'第一列', 'bb'=>'第二列', 'cc'=>'第三列', 'dd'=>'第四列'];

//模板文件路径(可更改,文件内定义表头与格式,第一行标题,第二行表头)

$file = EXTEND_PATH . 'files/excel.xls';

//加载模板

$phpexcel=\PHPExcel_IOFactory::createReader("Excel2007")->load($file);

$objActSheet = $phpexcel->getActiveSheet();

//写入标题

$objActSheet->setCellValue('A1', '标题');

//循环写入数据

$i = 0;

foreach ($data as $item) {

$row = 3 + $i;

$objActSheet->setCellValue('A' . $row, $i + 1);

$objActSheet->setCellValue('B'.$row,$item['aa']);

$objActSheet->setCellValue('C'.$row,$item['bb']);

$objActSheet->setCellValue('D'.$row,$item['cc']);

$objActSheet->setCellValue('E'.$row,$item['dd']);

$objActSheet->getRowDimension($row)->setRowHeight(40);//行高40

$i++;

}

生成方式(接下方导出):

//表头

$head = ['aa'=>'第一列', 'bb'=>'第二列', 'cc'=>'第三列', 'dd'=>'第四列'];

//导出数据

$data[] = ['aa'=>'aa', 'bb'=>'bb', 'cc'=>'cc', 'dd'=>'dd'];

$data[] = ['aa'=>'aa', 'bb'=>'bb', 'cc'=>'cc', 'dd'=>'dd'];

//创建新的PHPExcel对象

$phpexcel= new \PHPExcel();

$objActSheet = $phpexcel->getActiveSheet();

//设置表头

$key = ord("A");

$key2 = ord("A");

$colum2 = '';

foreach ($head as $k => $v) {

$colum = chr($key);

$objActSheet->setCellValue($colum2 . $colum . '2', $v);

if ($key < 90) {

$key += 1;

} else {

$key = ord("A");

$colum2 = chr($key2);

$key2++;

}

}

//标题

$objActSheet->setCellValue('A1', '标题')->mergeCells('A1:' . $colum . 1);

$row= 2;

foreach ($data as $rows) { //行写入

$span = ord("A");

$span2 = ord("A");

$j2 = '';

$row++;

foreach ($head as $k=>$value) {// 列写入

$j = chr($span);

$objActSheet->setCellValueExplicit($j2 . $j . $row, isset($rows[$k])?$rows[$k]:'', \PHPExcel_Cell_DataType::TYPE_STRING);

if ($span < 90) {

$span += 1;

} else {

$span = ord("A");

$j2 = chr($span2);

$span2++;

}

}

}

导出:

$fileName =  'excle.xls';

header('Content-Type: application/vnd.ms-excel');

header('Content-Disposition: attachment;filename=' . $fileName);

header('Cache-Control: max-age=0');

$objWriter = \PHPExcel_IOFactory::createWriter($phpexcel,'Excel2007');

$objWriter->save('php://output');

格式:

//创建新的工作表

$phpexcel->createSheet();

//选择工作表
$phpexcel->setActiveSheetIndex(0);

//重命名工作表

$phpexcel->getActiveSheet()->setTitle('Simple');

//单元格合并并设置值

$phpexcel->getActiveSheet()->setCellValue('A1', '值')->mergeCells('A1:E1' );

//设置字体

$phpexcel->getActiveSheet()->getStyle('A3:S' . $row )->getFont()->setName('Candara');

//设置字号

$phpexcel->getActiveSheet()->getStyle('A3:S' . $row )->getFont()->setSize(12);

//字体加粗

$phpexcel->getActiveSheet()->getStyle('A1:S'. $row )->getFont()->setBold(true);

//行高度

$phpexcel->getActiveSheet()->getRowDimension($row)->setRowHeight(40);

//列宽度

$phpexcel->getActiveSheet()->getColumnDimension('A')->setAutoSize(true);//自适应

$phpexcel->getActiveSheet()->getColumnDimension('A')->setWidth(300);

//表格画线

$styleArray=array('borders'=>array('allborders'=>array('style'=>\PHPExcel_Style_Border::BORDER_THIN,),),);

$phpexcel->getActiveSheet()->getStyle('A1:S' . $row)->applyFromArray($styleArray);

//文字居中

$phpexcel->getActiveSheet()->getStyle('A1:S' .$row)->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER)->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

//文字靠右

$phpexcel->getActiveSheet()->getStyle('A' .$row)->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);

//内容自动换行
$phpexcel->getActiveSheet()->getStyle('A1:S' .$row)->getAlignment()->setWrapText(TRUE);

//锁定(以B3单元格为分界线,上方和左方都会锁定)

$phpexcel->getActiveSheet()->freezePane('B3');

//设置下拉

$objValidation=$phpexcel->getActiveSheet()->getCell('C1' )->getDataValidation();

$objValidation->setType(\PHPExcel_Cell_DataValidation::TYPE_LIST)

        ->setErrorStyle(\PHPExcel_Cell_DataValidation::STYLE_INFORMATION )

->setAllowBlank(false)

->setShowInputMessage(true)

->setShowErrorMessage(true)

->setShowDropDown(true)

->setErrorTitle('输入的值有误')

->setError('您输入的值不在下拉框列表内.')

->setPromptTitle("标题")

->setPrompt("备注")

->setFormula1("选项一,选项二");

三:导入

$file = '路径';

$phpexcel = \PHPExcel_IOFactory::load($file);

$phpexcel->setActiveSheetIndex(0);//指定第一个工作表

$data= $phpexcel->getActiveSheet()->toArray(null, true, true, true);

tp5使用PHPExcel(下载引入/composer与模板/生成方式搭配使用)的更多相关文章

  1. tp5使用PHPWord(下载引入/composer两种方式)

    PHPWORD使用文档 一:引入 tp5.0,tp5.1: 1:composer方式(推荐) a:根目录下执行:composer require phpoffice/phpword b:引入: use ...

  2. TP5.0 PHPExcel 数据表格导出导入(引)

    TP5.0 PHPExcel 数据表格导出导入(引) 今天看的是PHPExcel这个扩展库,Comporse 下载不下来,最后只能自己去github里面手动下载,但有一个问题就是下载下来的PHPExc ...

  3. springmvc+mybatis下载项目自带模板

    1.首先如果要获取javaweb项目中的文件在哪,用到的代码:request.getSession().getServletContext().getRealPath("/WEB-INF/d ...

  4. 下载好的AE模板怎么用

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 下载好的AE模板怎么用_百度经验

  5. TP5.0 PHPExcel 数据表格导出(原)

    今天看的是PHPExcel这个扩展库,Comporse 下载不下来,最后只能自己去github里面手动下载,但有一个问题就是下载下来的PHPExcel没有命名空间,所以框架里面的use根本引入不进去, ...

  6. TP5.0 PHPExcel 数据表格导出导入(原)

    今天看的是PHPExcel这个扩展库,Comporse 下载不下来,最后只能自己去github里面手动下载,但有一个问题就是下载下来的PHPExcel没有命名空间,所以框架里面的use根本引入不进去, ...

  7. 项目中引入composer

    众所周知,composer可以自定义加载插件库和依赖,它也是用PHP写的,怎样在自己的项目中引入并使用composer呢?. 1.新建一个项目,在项目的根目录创建composer.json文件,用过一 ...

  8. laravel中引入composer安装在vendor中的第三方组件

    一.安装第三方组件 方法一:使用命令行安装第三方(已phpword为例): composer require phpoffce/phpword ^v0..* 方法二: 修改主项目composer.js ...

  9. tp5使用PHPexcel扩展导出excel表

    1,使用composer安装phpexcel包: composer require phpoffice/phpexcel 2,在控制器中创建方法: (1)使用PHPexcel扩展.代码如下 /** * ...

随机推荐

  1. [原题复现][2020i春秋抗疫赛] WEB blanklist(SQL堆叠注入、handler绕过)

    简介 今天参加i春秋新春抗疫赛 一道web没整出来 啊啊啊 好垃圾啊啊啊啊啊啊啊  晚上看群里赵师傅的buuoj平台太屌了分分钟上线 然后赵师傅还分享了思路用handler语句绕过select过滤.. ...

  2. python-网络安全编程第八天(实战高精度密码字典生成器)

    前言 emmmm 高精度密码字典源码 1.py import exrex import sys #url过滤处理 def host_para(host): if '://' in host: host ...

  3. CorelDRAW极具创意的多边形工具

    这是一个简单的教程,它展示了使用三种基本的CorelDRAW工具打造的创意性成果:多边形工具.挑选工具和形状工具. CorelDRAW 可让您以非常直观的方式创建多边形.尽管多边形工具乍看起来并不像一 ...

  4. guitar pro系列教程(二十二):Guitar Pro在乐谱上的工作【二】

    我们在上一篇文章中给大家介绍了Guitar Pro的工作面板和音轨功能,今天我们将会给大家介绍Guitar Pro这款吉他谱学习软件得音频设置面板,在该面板中包含了声卡得选择.MIDI的输入输出及音轨 ...

  5. 【Azure微服务 Service Fabric 】Service Fabric中应用开启外部访问端口及微服务之间通过反向代理端口访问问题

    问题描述 1) 当成功的在Service Fabric集群中部署了应用后,如何来访问呢?如果是一个Web服务,它的URL又是什么呢? 2) 当Service Fabric集群中,服务之间如需要相互访问 ...

  6. Linux三剑客grep、awk、sed

    何为Linux三剑客? 第一个剑客是 grep,grep 会根据正则表达式查找相关内容并打印对应的数据. 第二个剑客是 awk,awk 的名字来源于三个作者的名字简称,它可以根据定位到的数据行处理其中 ...

  7. mq中nio

    MappedFile#appendMessagesInner

  8. MFC二进制文件读取

    1.mfc Document-vew doc类中读取 doc类中读取,在Vew类中可直接使用. 在菜单栏NewFile/OpenFile 后,系统自动调用Serialize()函数 if :写入文件 ...

  9. 浅谈Abp vNext的模块化设计

    abp的模块化给我留下深刻的印象,模块化不是什么新概念,大家都习以为常,但是为什么要模块化,模块化的意义或者说目的是什么?也许我们思考得并不深入.难得的是abp不仅完美的阐述了模块化概念,而且把模块化 ...

  10. Feign 自定义 ErrorDecoder (捕获 Feign 服务端异常)

    问题描述 Feign 客户端捕获不到服务端抛出的异常 问题解决 重新 ErrorDecoder 即可,比如下面例子中在登录鉴权时想使用认证服务器抛出 OAuth2Exception 的异常,代码如下: ...