php操作Excel

1.new PHPExcel对象
$objPHPExcel = new PHPExcel();

2表的初始化设置
$objPHPExcel->getProperties()->setCreator($project_info['chief_name']) //创建人
->setLastModifiedBy($project_info['chief_name']) //最后修改人
->setTitle($project_info['chenghu'] . '先生/女士装修报价单') //标题
->setSubject($project_info['chenghu'] . '先生/女士装修报价单') //主题
->setDescription($project_info['chenghu'] . '先生/女士装修报价单') //描述
->setKeywords($project_info['chenghu'] . '先生/女士装修报价单') //关键词
->setCategory($project_info['chenghu'] . '先生/女士装修报价单'); //分类

//表格头部
$objPHPExcel->setActiveSheetIndex(0);//第一个sheet
$objPHPExcel->getActiveSheet()->setTitle($project_info['chenghu'] . '先生&女士装修报价单');//第一页对应的标题
$objPHPExcel->getDefaultStyle()->getFont()->setSize(13);//设置默认字体大小13

//表格内容

$objPHPExcel->getActiveSheet()->getStyle($cv)->getAlignment()->setWrapText(true);
$objPHPExcel->getActiveSheet()->getStyle($cv . ($bench + 1))->getFont()->setBold(true);//字体加粗

$objPHPExcel->getActiveSheet()->mergeCells('A' . ($bench + 1) . ':G' . ($bench + 1));//水平合并A-G的列
$objPHPExcel->getActiveSheet()->setCellValue('A' . ($bench + 1), $str);//设置单元格的值

$bench 代表行数
$colsymbol代表按顺序用到的列的集合,是个数组
$cellwidth 代表按顺序用到的单元格宽度的集合,是个数组
$rowheight 代表单元格高度的集合,是个数组

foreach ($rowheight as $rk => $rv) {
foreach ($colsymbol as $k => $cv) {
$objPHPExcel->getActiveSheet()->getColumnDimension($cv)->setWidth($cellwidth[$k]);
$objPHPExcel->getActiveSheet()->getRowDimension($rk + 1)->setRowHeight($rv);
if ($cv == 'G') {
$objPHPExcel->getActiveSheet()->mergeCells('A' . ($rk + 1) . ':G' . ($rk + 1));
$objPHPExcel->getActiveSheet()->setCellValue('A' . ($rk + 1), $headercontent[$rk]);
}
}
}

以上代码段奠定了这张表的格局

总体思路,以操作单元格为基准来定位,横坐标是行号,纵坐标是列数
设置单元格格式,设置单元格内容,合并单元格这几个常规操作的方法要运用自如

简单的导出
YiiUtils::exportExcel($title, $exceldata);

$title = date('Y-m-d').'数据';

var_dump($exceldata)的数据如下:

array (size=288)
0 =>
array (size=4)
0 => string '项目名称' (length=12)
1 => string '单位' (length=6)
2 => string '单价' (length=6)
3 => string '工艺说明及材料说明' (length=27)
1 =>
array (size=4)
0 => string '卫生间基层回填(从楼盘运碎砖)' (length=45)
1 => string '㎡' (length=3)
2 => string '250' (length=3)
3 => string '⑴用外楼盘碎砖及砼结构碎渣回填,从楼盘外运到工地。' (length=75)
2 =>
array (size=4)
0 => string '卫生间基层回填' (length=21)
1 => string '㎡' (length=3)
2 => string '11500' (length=5)
3 => string '⑴用本工地碎砖及砼结构碎渣回填(深度500mm以内)' (length=66)
3 =>
array (size=4)
0 => string '卫生间基层回填(从楼下运碎砖)' (length=45)
1 => string '㎡' (length=3)
2 => string '12000' (length=5)
3 => string '⑴用本楼盘其他碎砖及砼结构碎渣回填,楼下有碎砖需从楼下运到工地。' (length=96)
......

已key为行号,二维数组的每个值为列的值

/**
*
*读取excel文件中的第一个工作表并将内容已数组形式输出
*$filePath为上传文件的绝对路径
**/
public static function readExcel($filePath)
{
$PHPExcel = new PHPExcel();

/**默认用excel2007读取excel,若格式不对,则用之前的版本进行读取*/
$PHPReader = new PHPExcel_Reader_Excel2007();
if (!$PHPReader->canRead($filePath)) {
$PHPReader = new PHPExcel_Reader_Excel5();
if (!$PHPReader->canRead($filePath)) {
return array();
}
}
$contentArr = array();
$PHPExcel = $PHPReader->load($filePath);
/**读取excel文件中的第一个工作表*/
$currentSheet = $PHPExcel->getSheet(0);
/**取得最大的列号*/
$allColumn = $currentSheet->getHighestColumn();
/**取得一共有多少行*/
$allRow = $currentSheet->getHighestRow();
/**从第二行开始输出,因为excel表中第一行为列名*/
for ($currentRow = 2; $currentRow <= $allRow; $currentRow++) {
/**从第A列开始输出*/
$item = array();
for ($currentColumn = 'A'; $currentColumn <= $allColumn; $currentColumn++) {
$val = $currentSheet->getCellByColumnAndRow(ord($currentColumn) - 65, $currentRow)->getValue();
$item[] = $val;
}
$contentArr[] = $item;
}
return $contentArr;
}

php操作Excel的更多相关文章

  1. 免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)

    很多的软件项目几乎都包含着对文档的操作,前面已经介绍过两款操作文档的组件,现在介绍一款文档操作的组件NPOI. NPOI可以生成没有安装在您的服务器上的Microsoft Office套件的Excel ...

  2. C#通过NPOI操作Excel

    参考页面: http://www.yuanjiaocheng.net/webapi/create-crud-api-1-post.html http://www.yuanjiaocheng.net/w ...

  3. POI操作Excel

    POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...

  4. NPOI操作EXCEL(六)——矩阵类表头EXCEL模板的解析

    哈哈~~~很高兴还活着.总算加班加点的把最后一类EXCEL模板的解析做完了... 前面几篇文章介绍了博主最近项目中对于复杂excel表头的解析,写得不好,感谢园友们的支持~~~ 今天再简单讲诉一下另一 ...

  5. VB操作EXCEL文件

    用VB操作Excel(VB6.0)(整理) 首先创建Excel对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel. ...

  6. VB.NET操作Excel

    VB.NET操作Excel的基本方法与例子:

  7. C# 操作excel单元格居中

    C# 操作excel //导出Excel        private void ExportExcel(string fileName, System.Data.DataTable myDGV, s ...

  8. NPOI操作Excel辅助类

    /// <summary> /// NPOI操作excel辅助类 /// </summary> public static class NPOIHelper { #region ...

  9. JAVA的POI操作Excel

    1.1Excel简介 一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作表sheet,而一个工作表中包含多个单元格Cell,这些单元格都是由列(Column)行(Row)组 ...

  10. NPOI操作EXCEL(一)——npoi基础

    去年项目有一个子模块需要解析上百张不一样的excel表格入库,当时用的NPOI,做了很久...也尝试想把代码分享到oschina,结果没坚持两篇就放弃了. 赶巧的是,昨天运营那边提出要录入一些基础数据 ...

随机推荐

  1. JDK安装目录分析-两个jre和三个lib

    安装JDK后,Java目录下有jdk和jre两个目录,但jdk下还有一个jre目录,而且这个jre比前面那个jre在bin目录下少了个server文件夹(Server端的Java虚拟机)!前一个jre ...

  2. 【06】循序渐进学 docker:跨主机通信

    写在前面的话 目前解决容器跨主机通信的方案有很多种,这里给出的只是其中的一种,而且还不是最好的方案,不过归根结底,大同小异.在学习 docker swarm 之前,大家可以先看看这种. 啥是 over ...

  3. GPU大百科全书 第二章 凝固生命的光栅化

    光栅化——死神来了……   前言:在上一期的GPU大百科全书里,我们目睹了可爱的香草从抽象世界走向现实,从方程还原成实体的全过程.可以说香草活了,因为几何单元,我们赋予了她完整的灵魂. 如果你正在为G ...

  4. GPU大百科全书 第一章:美女 方程与几何

    沉鱼落雁   前言:当你酣战在星际2的时候,或者当你在艾泽拉斯游历的时候,你有没有想过,眼前的这些绚丽的画面究竟是怎么来的呢?也许对大多数人来说,GPU对于图形的处理过程并不是那么重要,但总会有些人, ...

  5. idea maven新建struts2项目

    环境: IDEA java1.8 struts2-core  2.5.18 一路下一步,名字自己随便填, 项目建好后修改pom.xml文件,加入struts2-core 添加tomcat: +号添加w ...

  6. “全栈2019”Java第十四章:二进制、八进制、十六进制

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  7. click事件和jquery选项卡

    一. click事件 实现效果是点击切换按钮,可以重复的切换背景色 <!DOCTYPE html> <html lang="en"> <head> ...

  8. Linux sort和uniq命令的应用

    sort: 选项: -b 忽略每行前面开始出的空格字符 -c 检查文件是否已经按照顺序排序 -d 排序时,处理英文字母.数字及空格字符外,忽略其他的字符 -f 排序时,将小写字母视为大写字母 -i 排 ...

  9. 做开发,你少不了的淘宝镜像之--maven镜像

    maven阿里云中央仓库 修改maven根目录下的conf文件夹中的settings.xml文件,内容如下: <mirrors>    <mirror>      <id ...

  10. 7.pytest中的 plugin

    一直想弄弄清这里的东西,一直各种因素delay,今天务必要搞搞清 一.先从官方文档上尝试去解读下什么是plugin和hook 网上有现成的对你适用的插件时候,我们可以直接pip安装,拿来使用即可:但是 ...