资讯专栏INFORMATION COLUMN

打造最全面的PHPExcel开发解决方案

ThinkSNS / 3247人阅读

摘要:过去工作中使用较多,碰到并解决了各种大大小小的问题,总结出这样一篇文章,一方面记录自己踩过的坑,一方面与大家分享,让大家少走弯路,并不断完善之,欢迎大家去上面和提交,不断补充和优化,打造最全面的开发解决方案地址原文地址基础小试牛刀引用文

过去工作中使用PHPExcel较多,碰到并解决了各种大大小小的问题,总结出这样一篇文章,一方面记录自己踩过的坑,一方面与大家分享,让大家少走弯路,并不断完善之,欢迎大家去github上面star和提交pull request,不断补充和优化,打造最全面的PHPExcel开发解决方案

Github 地址:https://github.com/tony-yin/P...
原文地址:https://tony-yin.github.io/20...

基础:小试牛刀 1. 引用文件
yourpath . /phpexcel/PHPExcel.php
2. 实例化phpexcel类
$excel = new PHPExcel();
3. 获取当前单sheet(多sheet会在下面讲)
$objexcel = $excel->getActiveSheet();
4. 合并单元格
$objexcel->mergeCells("A1:M1");
5. 获取一个cell的样式
$objexcel->getStyle("A1");

获取一个cell的字体样式

$cellFont = $objexcel->getStyle("A1")->getFont();

设置字体大小

$fontStyle->setSize(15);

设置字体是否加粗

$fontStyle->setBold(true);

设置字体颜色

$fontStyle->getColor()->setARGB(PHPExcel_Style_Color::COLOR_RED);

获取一行样式

$rowStyle = $objexcel->getStyle(1)->getRowDimension();

设置行高度

$rowStyle->setRowHeight(2);

获取一列样式

$columnStyle = $objexcel->getStyle("A")->getColumnDimension();

设置列宽度

$columnStyle->setWidth(10);

获取一列对齐样式

$alignStyle = $objexcel->getStyle("A")->getAlignment();

设置水平居中:同一水平线上居中,即为左右的中间

$alignStyle>setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

设置垂直居中:同一垂直线居中,即为上下的中间

$alignStyle->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);

自动换行

$$alignStyle->setWrapText(true);
6. 获取指定版本excel写对象

如需更早的版本可将Excel2007换成Excel5

$write = PHPExcel_IOFactory::createWriter("xcel, "Excel2007");
进阶:一些有用的小知识 1.行列数字索引方法

phpexcel一般获取cell或者获取列都是通过ABC这样的英文字母获取的,它也可以通过0、1、2、3这样的数字表示sheet中的列,从0开始,0对应A1对应B,基本上大多数方法都是数字行列索引,例如getStyleByColumnAndRow($col,$row),默认列参数在前,行参数在后,更多的可以参加phpexcel源码;

2. 单行或单列参数格式

有的时候一个方法需要行列两个参数,例如只需要某一行参数可写成(null, $row),例如只需要获得某一列参数可写成($col, null)

3. 列的数字索引格式和字母索引格式互转

数字转字符串

PHPExcel_Cell::columnIndexFromString("A");  // Return 1 not 0;

字符串转数字

PHPExcel_Cell::stringFromColumnIndex(0);    // Return "A";
4.PHPExcel读取数字类型

PHPExcel读取的cell数字,类型都是double型,可用gettyle()方法检测类型,当初我一直使用is_int()方法无果,搞得焦头烂额。。。

5. 多cell边框线设置

PHPExcel生成的表格如果你不加处理,是不会帮你生成边框线的,生成边框线的方法如下:

$borderArray = array(
    "borders" => array(
        "allborders" => array(
            "style" => PHPExcel_Style_Border::BORDER_THIN
        )
    )
);
$objexcel->getStyle($col1, $row1,$col2, $row2)->applyFromArray($borderArray);

注:

getStyle()可以看需求改为getStyleByColumnAndRow()方法通过数字行列索引读取style

array中PHPExcel_Style_Border::后面有三种格式分别是BORDER_THINBORDR_MEDIUM,表示边框线的粗细;

getStyle()中的索引可以是静态的,也可以是动态的,一般是在导出excel的数据set完毕后填写左上角的单元格行列索引和右下角的单元格行列索引;

参考资料

http://phpexcel.codeplex.com/...
http://phpexcel.codeplex.com/...

6. 多cell字体加粗处理
$objexcel->getStyle($pCoordinate)->applyFromArray(array(
    "font" => array(  
        "bold" => true,                                              
    ),                                                               
));
7. 多cell字体颜色处理
$objexcel->getStyle($pCoordinate)->applyFromArray(array(
    "font" => array(
        "color" => array(
            "rgb" => "ff0000",
            ),
        ),
    )
);
8. 多sheet导入

动态为当前sheet设置索引,然后获取当前sheet,便可循环读取每一个sheet内容

$objexcel->setActiveSheetIndex($index);   //$index = 0 1 2 3
$objexcel->getActiveSheet();    //return sheet1 sheet2 sheet 3
9. 固定格式excel读取在写入

当需求是给定一个一个模板excel,需要往里面塞数据,我们不一定要通过代码给它设定样式,如果这个模板变化不大,我们完全可以存放一个格式相同的静态文件,然后通过PHPExcel读取,再往里面塞数据,最后进行保存操作,可以达到一样的效果,并且可以节省大量的资源。

10. 合并单元格导入问题

在特殊的表格中,合并单元格普遍存在,而多个单元格合并成的一个单元格,只能setValue()一次,而我们如何判断合并单元格的具体行列呢?

$range = $start_cell->getMergeRange();  // 通过合并单元格的开始单元格比如‘A1’,获取合并范围‘A1:A4’
$cell->isInRange($range);    // 遍历之后每一个单元格便可通过isInRange()方法判断当前单元格是否在合并范围内
高级:特殊场景特殊手段 1. 单元格文本格式数据处理

一般excel单元格中数据的格式为数据类型,而PHPExcel中的getValue()方法读取的也是数据类型,当把数据从数据类型改为文本类型后,在PHPExcel中读出来的是PHPExcel_RichText类型,getValue()读取返回PHPExcel_RichText是一个object类型(PHPExcel_RichText数据保存格式);那如何读取这一类的数据呢?仔细查看读取出来的对象,不难发现有getPlainText()这样的方法可以读取文本类型数据,所以我们只要判断当当前数据为文本数据时用getPlainText()读取,一般数据用getValue()读取

if ($cell->getValue() instanceof PHPExcel_RichText) {
    $value = $cell->getValue();
} else {
    $value = $cell->getValue();
}

参考资料

http://www.cnblogs.com/DS-CzY...
http://phpexcel.codeplex.com/...

2. 单元格数据算法处理

excel拥有强大的算法功能,一般算法格式为=A3+A4这类的,复杂的更多,如果使用PHPExcel提供的默认读取方法getValue()读取出来的结果则为字符串=A3+A4,好在PHPExcel也足够强大,提供了相应的接口:getCalculatedValue(),这个方法专门读取算法数据,但是我们不能将这个方法作为默认读取方法,因为这样可能会将一些本来要读成字符串的读成算法数据,而且PHPExcel没有将它作为默认读取方法的另一个重要原因就是算法方式读取很耗时间和性能,一般数据读取根本没有必要这样浪费资源,所以我们可以采用以下这种方式

if (strstr($cell->getValue(), "=")) {   
    // 判断如果cell内容以=号开头便默认为算法数据
    $value = $cell->getCalculatedValue(); 
} else {
    $value = $cell->getValue();
}
3. 日期数据处理

除了以上所说的文本数据和算法数据外,我还遇到过日期类型数据,比如2016-12-28输入到excel中,它会默认转换成2016/12/28,如果采用一般的getValue()方式读取也会读取到错误的数据,PHPExcel也提供了相应的接口getFormattedValue(),并提供了适配的识别方式PHPExcel_Shared_Date::isDateTime($cell),所以代码就很好实现了

if (PHPExcel_Shared_Date::isDateTime($cell)) {
    $value = $cell->getFormattedValue(); 
} else {
    $value = $cell->getValue();
}
4. 读取方法封装

针对excel各种数据类型,我们可以写一个函数,将原有的getValue()封装一下,这样以后就不用每次都判别一下数据类型了,目前我只遇到上面三种特殊格式,如果有新的,欢迎大家补充,封装函数如下

function get_value_of_cell($cell) {
    if (strstr($cell->getValue(), "=")) {   
        $value = $cell->getCalculatedValue(); 
    } else if ($cell->getValue() instanceof PHPExcel_RichText) {
        $value = $cell->getValue();
    } else if (PHPExcel_Shared_Date::isDateTime($cell)) {
        $value = $cell->getFormattedValue(); 
    } else {
        $value = $cell->getValue();
    }
}
5. 导出文件在IE、360等浏览器中文件名中文乱码问题
$filename = "xxx导出表";
// 判断如果是IE内核形式的浏览器采用urlencode处理文件名
if (!preg_match("/Firefox/", $_SERVER["HTTP_USER_AGENT"])) {
    $filename = urlencode($filename);
}

未完待续。。。
期待你的补充和优化

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/25854.html

相关文章

  • php 导出 excel

    关于 PHP 导出 excel csv 常用的有 PHPexcel ,本文整理了一些其他方案。 高性能 Excel 扩展 sudo apt-get install -y zlib1g-dev git clone https://github.com/jmcnamara/libxlsxwriter.git cd libxlsxwriter make && sudo make install // ...

    付永刚 评论0 收藏0
  • 使用PHP_XLSXWriter代替PHPExcel

    摘要:能不能单独设置某个单元格的值这个目前并没有实现,现在数据的写入都是逐行写入的,不支持这么细的粒度,不过折中的做法是把不需要填充的单元格写入即可如果有什么使用问题,可以在下面留言,一起探讨使用方式 二者有何区别? PHPExcel 是一个处理Excel,CVS文件的开源框架,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格,这也是PHP至今最通用的Ex...

    TZLLOG 评论0 收藏0
  • 使用PHPExcel读写excel

    摘要:要求,使用了名字空间编码规范最新的语言新特性对版本的要求加强。已经放出稳定版,官方不再建议使用。保存和导入的行为分别由和负责。注意不要混淆和对象持有数据,和是对其进行序列化和反序列化的辅助类。单元隶属于具体的表单,使用上和表单类互动最多。 转载请注明文章出处:https://tlanyan.me/use-phpexc... PHPOffice出品的PHPExcel是PHP读取和生成Ex...

    wupengyu 评论0 收藏0
  • 【PHP】PHPExcel类 excel常用操作小结

    摘要:使用好久了,好像今天才想起来要记一篇博客呢。之前一直用的框架,后来做接口的时候打算换成不料机缘巧合之下又结识了,于是乎决然的站到了的大营之下。今天小记一下这个类库的常用操作。首先贴上地址,直接去下载最新版好了。 PHP使用好久了,好像今天才想起来要记一篇博客呢。之前一直用的 ci 框架,后来做接口的时候打算换成 tp5, 不料机缘巧合之下又结识了 node,于是乎决然的站到了 js 的...

    suosuopuo 评论0 收藏0
  • WEB前端资源集(一)

    摘要:资源网站篇全球最大中文社区,为专业技术人员提供最全面的信息传播和服务平台伯乐在线专业的互联网职业社区创意工作者们的社区。 做前端已经一年了,开发中换过很多开发工具,遇到bug到处求解,以及自学时到处找相关文章及教程,所以经过这么多的风波,我总结了一些对大家有帮助的网站,主题也将长期更新。 资源网站篇 CSDN:全球最大中文IT社区,为IT专业技术人员提供最全面的信息传播和服务平台 ...

    OnlyMyRailgun 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<