YII2+PHPEXCEL

Yii2使用PHPExcel读取excel,有需要的朋友可以参考下。

个人使用过程中保存一些使用PHPExcel的经验,以便后来翻阅:

与PHP的Yii框架结合,可以轻松使用。而且根本不用网上所说的修改Yii的自动加载文件等方法。

具体使用方法:

下载phpofficehttp://phpexcel.codeplex.com/releases/view/119187

下载后首级目录结构是 Classes, Documentation, Examples, changelog.txt, install.txt, license.txt.

其中一种方法

下载后要做的就是让Yii加载PHPExcel. lele模仿yii2-swiftmailer的加载方式,修改项目根路径下的composer.json, 在"require"中加入"phpoffice/phpexcel": "dev-develop",然后用命令行进入根目录,执行composer update, (好像不用手动下载phpexcel,composer会自动下好。。。)完成后可以在php中使用$PHPExcel = new /PHPExcel();来得到一个实例。切记,new时一定要加/, 不然会报类找不到的错误(lele不知道为什么要加/, 有谁知道请在评论里说一下)。

第二种方法

把phpexcel放入vendor即可

OK, 能用了之后呢,写一些使用的代码:

$filePath = "../file/test.xlsx"; // 要读取的文件的路径

$PHPExcel = new \PHPExcel(); // 拿到实例,待会儿用

$PHPReader = new \PHPExcel_Reader_Excel2007(); // Reader很关键,用来读excel文件

if (!$PHPReader->canRead($filePath)) { // 这里是用Reader尝试去读文件,07不行用05,05不行就报错。注意,这里的return是Yii框架的方式。
$PHPReader = new \PHPExcel_Reader_Excel5();
if (!$PHPReader->canRead($filePath)) {
$errorMessage = "Can not read file.";
return $this->render(‘error‘, [‘errorMessage‘ => $errorMessage]);
}
}

$PHPExcel = $PHPReader->load($filePath); // Reader读出来后,加载给Excel实例

-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-

以上就可以读excel了,下面遍历输出这个二维表格。PHPExcel的方法名字比较语义化。

$allSheet = $PHPExcel->getSheetCount(); // sheet数

$currentSheet = $PHPExcel->getSheet(0); // 拿到第一个sheet(工作簿?)

$allColumn = $currentSheet->getHighestColumn(); // 最高的列,比如AU. 列从A开始

$allRow = $currentSheet->getHighestRow(); // 最大的行,比如12980. 行从0开始

$result = new ReadFileResult(); // result是我自己写的一个存放结果的实体类

for ($currentRow = 1; $currentRow <= $allRow; $currentRow++) {
echo $currentRow;
$lineVal = [];

for ($currentColumn="A"; $currentColumn <= $allColumn; $currentColumn++) {
$val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65, $currentRow)->getValue(); // ord把字母转为ascii码,A->65, B->66....这儿的坑在于AU->65, 后面的U没有计算进去,所以用索引方式遍历是有缺陷的。
array_push($lineVal, $val);
}
array_push($result->content, $lineVal);
}

看开发文档发现,还有两个非常好用的遍历方式。

一,用toArray把这个sheet转为二维数组。

$currentSheet->getStyle(‘A2:A6‘)->getNumberFormat()->setFormatCode(‘yyyy-mm-dd‘); // 转为A2到A6的时间格式

$result->content = $currentSheet->toArray(‘‘, true, true); // 把当前sheet转为二维数组

二,用PHPExcel自带的行列迭代器。这样会稳妥许多。

foreach ($currentSheet->getRowIterator() as $row) { // 行迭代器
$cellIterator = $row->getCellIterator(); // 拿到行中的cell迭代器
$cellIterator->setIterateOnlyExistingCells(false); // 设置cell迭代器,遍历所有cell,哪怕cell没有值
$lineVal = [];
foreach ($cellIterator as $cell) {
if ($cell->getDataType() == /PHPExcel_Cell_DataType::TYPE_NUMERIC) { // 这里是比较cell中数据类型是不是number
$cellStyleFormat = $cell->getStyle( $cell->getCoordinate() )->getNumberFormat(); // 接下来这两句是拿到这个number的格式
$formatCode = $cellStyleFormat->getFormatCode(); // 如果是普通的数字,formatCode将为General, 如果是如6/12/91 12:00的时间格式,formatCode将为/d/yy h:mm(反正就是时间格式了)
echo $cell->getCoordinate() . " " . $formatCode; echo "<br>";
if (preg_match("/m//d//yy h:mm/i", $formatCode)) {
$value = gmdate("Y-m-d H:i:s", /PHPExcel_Shared_Date::ExcelToPHP($cell->getValue())); // 这里是将Excel的时间按格式转为PHP的时间
} else {
$value = $cell->getValue();
}
} else {
$value = $cell->getValue();
}
if ($cell->getColumn() == ‘I‘) { // 拿到列坐标
$value = "0" . $value;
}
array_push($lineVal, $value . " " . $cell->getColumn());
}
array_push($result->content, $lineVal);
}

lele从yanhui_wei同学一篇文章看到了TA对PHPExcel类及方法的总结,写的不错,特摘抄下来:

对于常见的excel报表操作,我们需要掌握如下几个类库就可以了:

(1)PHPExcel:工作簿对象

excel文档处理对象主要用来管理我们的excel文档,怎么来管理(通过属性和方法来管理)?大家知道,类主要是由属性和方法来组成,通过php程序的手段来管理excel文档,其实就是通过本对象的属性和方法来管理,下面我们就来看一下PHPExcel类中都有那些属性和方法,这些属性和方法主要用来管理excel文档的那些方面
getProperties():获得当前活动状态工作表的属性对象,返回属性对象
getActiveSheet():获得当前活动状态的工作表,返回工作表对象
getActiveSheetIndex():获得当前活动状态工作表的索引值,返回int
setActiveSheetIndex():设置当前活动状态工作表的索引,返回工作表对象
getSheetByName():通过工作表名称得到当前工作表对象,返回工作表对象
getDefaultStyle():获得excel文档默认的样式(所有工作表的样式),返回样式对象
createSheet():在当前活动工作表后创建一个新的工作表
getSheetCount():获得excel文档中工作表的数量,返回int
getSheetNames():获得excel文档中所有工作表名称组成的数组

(2)PHPExcel_Worksheet:工作表对象

工作表对象,主要用来管理我们的工作表,怎么管理?也是通过属性和方法来管理,但是工作表对象大部分情况下可通过excel文档对象来获取

toArray():把工作表中的数据转换成数组
fromArray():从数组中获取数据填充到工作表,返回工作表对象
getCell():获得单元格对象
getCellByColumnAndRow():通过列索引和行索引获得指定单元格,返回单元格对象
getDefaultStyle():获得工作表默认的样式,返回样式对象
getHighestColumn():获得工作表的最大列,返回列的名称
getColumnDimension():获得当前列
getStyle():获得指定单元格的样式,返回样式对象
getParent():获得父类对象,返回excel文档对象
getTitle():获得工作表的标题或名称,返回字符串类型
setCellValue():设置单元格的值,返回工作表对象或单元格对象,完全取决于参数的值
setCellValueByColumnAndRow():通过列索引和行索引设置单元格的值,返回类型同上
setCellValueExplicit():设置单元格的值,并显示指定数据类型,返回工作表对象
setCellValueExplicitByColumnAndRow():通过列和行索引设置单元格值
setTitle():设置工作表标题

(3)PHPExcel_Cell:单元格对象

(4)PHPExcel_Style:样式对象,主要用来设置单元格的样式:对齐方式、字体、边框、填充等,跟我们之前学过的css样式差不多,在这里如果想要设置对齐方式、字体大小、边框颜色、等等都是通过样式对象来完成的

getActiveCell():获得当前活动的单元格的名称,返回string;如,A1
getActiveSheet():获得当前活动的工作表,返回工作表对象
getAlignment():获得对齐方式对象,返回对齐方式对象
getBorders():获得边框对象,返回边框对象
getFill():获得填充对象
getFont():获得字体对象
setFont():设置字体,返回样式对象

(5)PHPExcel_Style_Alignment:对齐方式对象

getHorizontal():获得水平居中方式
getVertical():获得垂直居中方式
setHorizontal():设置水平居中方式,返回对齐方式对象
setVertical():设置垂直居中方式,返回对齐方式对象

居中方式:
HORIZONTAL_CENTER
HORIZONTAL_CENTER_CONTINUOUS
HORIZONTAL_GENERAL
HORIZONTAL_JUSTIFY
HORIZONTAL_LEFT
HORIZONTAL_RIGHT
VERTICAL_BOTTOM
VERTICAL_CENTER
VERTICAL_JUSTIFY
VERTICAL_TOP

(6)PHPExcel_Style_Font:字体对象

setBold():设置字体加粗
setColor():设置字体颜色
setItalic():设置字体倾斜
setName():设置字体名
setSize():设置字体大小
setUnderline():设置字体下划线

(7)PHPExcel_Writer_Excel5:写操作对象,主要用来输出xls文件

save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中

(8)PHPExcel_Writer_Excel2007:写操作对象,主要用于输出xlsx文件

save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中

(5)PHPExcel_Reader_Excel5:读操作对象,主要用于输入xls文件

canRead():当前reader对象是否能够读工作簿文件
load():从一个工作簿文件中加载工作簿对象,也就是将工作簿文件中的数据加载到工作簿对象中来管理

(9)PHPExcel_IOFactory:读写操作对象

createReader():根据参数的不同,创建不同的读对象:主要作用是读取工作簿文件中的数据

createWriter():根据参数的不同,返回不同的写对象:主要作用是将PHPExcel工作簿对象中的数据写入到一个工作簿文件中

load():从工作簿文件中加载PHPExcel工作簿对象,即:将工作簿文件中数据加载到PHPExcel工作簿对象中来管理

PHPExcel对象:是一个工作簿对象

include_once "PHPExcel/Writer/Excel5.php";//主要用于其它低版本,且文件名后缀为xls的文件,如果我们希望生成后缀名为xls格式的excel文件,建议引入此类库

include_once "PHPExcel/Writer/Excel2007.php";//主要用于excel2007格式,文件名后缀为xlsx的excel文件,如果我们希望生成后缀名为xlsx格式的excel文件,建议引入此类库

$objWriter = new PHPExcel_Writer_Excel5($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于其它板式的格式

$objWriter = new PHPExcel_Writer_Excel2007($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于excel2007格式
$objWriter->setOffice2003Compatibility(true);//兼容office2003

//设置文档基本属性 
$objProps = $objExcel->getProperties(); //得到PHPExcel_document文档对象
$objProps->setCreator("Zeal Li"); //设置作者
$objProps->setLastModifiedBy("Zeal Li"); //设置最后修改时间
$objProps->setTitle("Office XLS Test Document"); //设置标题
$objProps->setSubject("Office XLS Test Document, Demo");//设置主题
$objProps->setDescription("Test document, generated by PHPExcel.");//描
$objProps->setKeywords("office excel PHPExcel"); //关键字
$objProps->setCategory("Test"); //分类

$objExcel->setActiveSheetIndex(0);//设置用户打开excel文件时,看到的首张sheet,如果没有设置,默认为最后一次操作的sheet

$objActSheet->setTitle(‘测试Sheet‘);//设置当前活动的工作簿名称

//根据单元格名称设置单元格内容,由PHPExcel根据传入的内容自动判断单元格的内容类型
$objActSheet->setCellValue(‘A1‘, ‘字符串内容‘); // 字符串内容
$objActSheet->setCellValue(‘A2‘, 26); // 数值
$objActSheet->setCellValue(‘A3‘, true); // 布尔值
$objActSheet->setCellValue(‘A4‘, ‘=SUM(A2:A2)‘); // 公式

/显式指定单元格的内容类型为字符串类型 
$objActSheet->setCellValueExplicit(‘A5‘,‘847475847857487584‘,PHPExcel_Cell_DataType::TYPE_STRING);

//合并单元格 
$objActSheet->mergeCells(‘B1:C22‘);

//设置列的宽度 
$objActSheet->getColumnDimension(‘B‘)->setAutoSize(true);
$objActSheet->getColumnDimension(‘A‘)->setWidth(30);

//设置行的高度
$objPHPExcel->getActiveSheet()->getRowDimension(‘2‘)->setRowHeight(11.5);

//格式:主要用来对单元格进行操作,如,设置字体、设置对齐方式、设置边框等
$objStyleA5 = $objActSheet->getStyle(‘A5‘);//获取A5单元格的样式

//设置单元格的字体
$objFontA5 = $objStyleA5->getFont(); //获得字体
$objFontA5->setName(‘宋体‘);//设置字体名称
$objFontA5->setSize(10); //设置字体大小
$objFontA5->setBold(true);//设置字体加粗
$objFontA5->getColor()->setARGB(‘FF999999‘);//设置字体颜色

//设置单元格的对齐方式 
$objAlignA5 = $objStyleA5->getAlignment();//获得对齐方式
$objAlignA5->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);//水平居右
$objAlignA5->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);//垂直居中

//设置单元格的边框 
$objBorderA5 = $objStyleA5->getBorders();//获取边框
$objBorderA5->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//边框样式
$objBorderA5->getTop()->getColor()->setARGB(‘FFFF0000‘);//顶部边框的颜色
$objBorderA5->getBottom()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
$objBorderA5->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//左样式
$objBorderA5->getRight()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//右样式

//设置单元格的填充色
$objFillA5 = $objStyleA5->getFill();//填充
$objFillA5->setFillType(PHPExcel_Style_Fill::FILL_SOLID);//填充类型
$objFillA5->getStartColor()->setARGB(‘FFEEEEEE‘);

//计算单元格的值
$objPHPExcel->getActiveSheet()->setCellValue(‘B7‘, ‘=SUM(B5:C5)‘);
$objPHPExcel->getActiveSheet()->getCell(‘B7‘)->getCalculatedValue();
//如果要获取单元格的一个值,首先需要通过工作表的getCell方法获取到一个单元格对象,然后再通过单元格对象的getValue方法得到单元格的值,如果单元格的值是通过计算得到的,则需要使用getCalculatedValue方法获取单元格的值,设置单元格的值,我们只需要通过工作表的setCellValue方法来设置即可

//$dateTimeNow=time();
$objPHPExcel->getActiveSheet()->setCellValue(‘C10‘, PHPExcel_Shared_Date::PHPToExcel( $dateTimeNow ));//41105.75

$objPHPExcel->getActiveSheet()->getStyle(‘C10‘)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_TIME4);//18:00:54,只是换了一种显示方式,并不会改变原来值的类型

echo gettype($objPHPExcel->getActiveSheet()->getCell(‘C10‘)->getValue());//double
echo $objPHPExcel->getActiveSheet()->getCell(‘C10‘)->getValue();//41105.75

//‘2010-10-21‘一定要放在引号中,否则显示的值为,1979文本(推荐)
$objPHPExcel->setActiveSheetIndex(0)->setCellValueExplicit("D1", ‘2010-10-21‘, PHPExcel_Cell_DataType::TYPE_STRING); //特征:字符串类型都是居左显示

//添加一个新的worksheet 
$objExcel->createSheet();//创建一个新的工作表
$objExcel->getSheet(1)->setTitle(‘测试2‘);//设置当前工作表的标题

//保护单元格 
$objExcel->getSheet(1)->getProtection()->setSheet(true);
$objExcel->getSheet(1)->protectCells(‘A1:C22‘, ‘PHPExcel‘);

//输出内容到excel文件,并将文件保存在服务器上
$objWriter->save("test.xls");

//强制输出内容到浏览器下载 
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header(‘Content-Disposition:inline;filename="‘.$outputFileName.‘"‘);
header("Content-Transfer-Encoding: binary");
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: no-cache"); 
$objWriter->save(‘php://output‘);//参数-表示直接输出到浏览器,供客户端下载

//excel读取对象
$PHPReader = new PHPExcel_Reader_Excel5();//创建一个excel文件的读取对象
$PHPExcel = $PHPReader->load($filePath);//读取一张excel表,返回excel文件对象
$currentSheet = $PHPExcel->getSheet(0);//读取excel文件中的第一张工作表
$allColumn = $currentSheet->getHighestColumn();//取得当前工作表最大的列号,如,E
$allRow = $currentSheet->getHighestRow();//取得当前工作表一共有多少行

//设置工作簿默认的样式
$objPHPExcel->getDefaultStyle()->getFont()->setName(‘Arial‘);
$objPHPExcel->getDefaultStyle()->getFont()->setSize(8);

//合并单元格
$objPHPExcel->getActiveSheet()->mergeCells(‘A18:E22‘);

时间: 2024-10-08 19:35:02

YII2+PHPEXCEL的相关文章

yii2.0 框架 载入 PHPExcel 类

我用的是composer 安装的, 自己引入的话找了好多的方法但是都不能引入 所以找了这个简单一点的. composer require "phpoffice/phpexcel"    用这个命令下载就可以(等一会时间),前提是你已经安装的composer 如果没有,就安装一个,就不多说了. 安装完成后 window 下打开命令窗口 输入compposer 查看是否安装成功,然后打开你的yii2.0(高级版)框架的verdor 这个文件夹 Shift+右键,打开命令窗口,运行上面那个下

PHPExcel yii2 加载使用

除了用composer 包管理组件的方式外 我们还可以使用 直接最原始的加载方式---超级简单 1.PHPExcel上下载最新的PHPExcel http://phpexcel.codeplex.com/ 把下载包解压 将其中的class文件夹复制 到yii2下 common/widgets/目录下 将Class改名为phpexcel (因为包是直接从官网上下载的 并不支持 yii 的自动加载功能所以命名空间也省得写了) 2.在需要用到phpexcel的地方 将phpexcel 文件夹下的PHP

Yii2框架RESTful API教程(二) - 格式化响应,授权认证和速率限制

之前写过一篇Yii2框架RESTful API教程(一) - 快速入门,今天接着来探究一下Yii2 RESTful的格式化响应,授权认证和速率限制三个部分 一.目录结构 先列出需要改动的文件.目录如下: web ├─ common │ └─ models │ └ User.php └─ frontend ├─ config │ └ main.php └─ controllers └ BookController.php 二.格式化响应 Yii2 RESTful支持JSON和XML格式,如果想指定

Yii2 Unable to verify your data submission

出现这种错误第一时间是怀疑CSRF没有填写的原因,不建议网上所说的关闭csrf,这存在安全隐患,于是直接在表单填写<input type="hidden" name="_csrf" id='csrf' value="<?= Yii::$app->request->csrfToken ?>"> 重新提交以下,还是同样的问题,于是追踪源码,发现name的名称有误,我使用的是yii2的高级后台模板,准确的name名称

YII2框架详解

yii2框架的安装我们在之前文章中已经提到下面我们开始了解YII2框架 Yii2的应用结构: 目录篇: advance版本的特点是:根目录下预先分配了三个模块,分别是前台.后台.控制台模块. 1.backend 它主要用于管理后台,网站管理员来管理整个系统. assets 目录用于存放前端资源包PHP类. 这里不需要了解什么是前端资源包,只要大致知道是用于管理CSS.js等前端资源就可以了. config 用于存放本应用的配置文件,包含主配置文件 main.php 和全局参数配置文件 param

Yii2系列教程四:实现用户注册,验证,登录

上一篇写了一点点Yii2的数据库相关知识和强大的Gii,这一篇就如上一篇的最后所说的一样:在Yii2中实现用户的注册和登录. 你可以直接到Github下载源码,以便可以跟上进度,你也可以重头开始,一步一步按照这个教程来做.本期的用户注册和登录,我会使用一个很棒的composer package :dektrium/yii2-user,下面就开始我们的故事吧. 用户的注册和登录 在现在的Web应用中,几乎每一个应用都会需要用户注册,不管是使用的第三方还是自建的注册登录系统,我们都需要通过某些表单来

yii2使用多个数据库的案例

作者:白狼 出处:http://www.manks.top/article/yii2_%E5%88%86%E5%BA%93%E5%88%86%E8%A1%A8_config本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利. 关于yii2配置操作多个数据库进行操作,文档上面也给出了具体的配置,一个实战性的例子,也是很简单的,我们这里以权限控制为单个管理库dbname2,业务库dbname 为例来看看如何配置多个数据库. No1.

Yii2的深入学习--自动加载机制

Yii2 的自动加载分两部分,一部分是 Composer 的自动加载机制,另一部分是 Yii2 框架自身的自动加载机制. Composer自动加载 对于库的自动加载信息,Composer 生成了一个 vendor/autoload.php 文件.你可以简单的引入这个文件,你会得到一个自动加载的支持. 在之前的文章,入口文件的介绍中,我们可以看到如下内容: // 引入 vendor 中的 autoload.php 文件,会基于 composer 的机制自动加载类 require(__DIR__ .

PhpExcel使用方法

下面是总结的几个使用方法 include 'PHPExcel.php'; include 'PHPExcel/Writer/Excel2007.php'; //或者include 'PHPExcel/Writer/Excel5.php'; 用于输出.xls的 创建一个excel $objPHPExcel = new PHPExcel(); 保存excel-2007格式 $objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel); //或者$o