首页 技术 正文
技术 2022年11月7日
0 收藏 603 点赞 957 浏览 1908 个字

PHPExcel 是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格,如 Excel (BIFF) .xls, Excel 2007 (OfficeOpenXML) .xlsx, CSV, Libre/OpenOffice Calc .ods, Gnumeric, PDF, HTML等等。

$excel->getActiveSheet()->mergeCells('A1:F1');      //合并单元格
$excel->getActiveSheet()->setCellValue("A1","我是标题");

单元格居中、并加粗:

        $excel->getActiveSheet()->getStyle('A1')->applyFromArray(
array(
'font' => array (
'bold' => true
),
'alignment' => array(
'horizontal' => PHPExcel_Style_Alignment::HORIZONTAL_CENTER
)
)
);

参考:

http://www.sdhack.com/20121163.html   先请模板,再写入(实用)

<?php
include('PHPExcel.php');
//这些数据假设是从M('xxx')->select()里面出来的
$data = array (
array ('id' => , 'name' => '张三' ), array ('id' => , 'name' => '李四' ), array ('id' => , 'name' => '王五' ) );
//PHPExcel支持读模版 所以我还是比较喜欢先做好一个Excel的模版 比较好,不然要写很多代码 模版我放在根目录了
//创建一个读Excel模版的对象
$objReader = PHPExcel_IOFactory::createReader ( 'Excel5' );
$objPHPExcel = $objReader->load ("template.xls" );
//获取当前活动的表
$objActSheet = $objPHPExcel->getActiveSheet ();
$objActSheet->setTitle ( '演示工作表' );
$objActSheet->setCellValue ( 'A1', '这个是PHPExcel演示标题' );
$objActSheet->setCellValue ( 'A2', '日期:' . date ( 'Y年m月d日', time () ));
$objActSheet->setCellValue ( 'F2', '导出时间:' . date ( 'H:i:s' ) );
//我现在就开始输出列头了
$objActSheet->setCellValue ( 'A3', '序号' );
$objActSheet->setCellValue ( 'B3', '姓名' );
//具体有多少列 看你的数据走 会涉及到计算
//现在就开始填充数据了 (从数据库中) $data
$baseRow = ; //数据从N-1行开始往下输出 这里是避免头信息被覆盖
foreach ( $data as $r => $dataRow ) {
$row = $baseRow + $r;
//将数据填充到相对应的位置
$objPHPExcel->getActiveSheet ()->setCellValue ( 'A' . $row, $dataRow ['id'] ); //学员编号
$objPHPExcel->getActiveSheet ()->setCellValue ( 'B' . $row, $dataRow ['name'] ); //真实姓名
}
//导出
$filename = time ();
header ( 'Content-Type: application/vnd.ms-excel' );
header ( 'Content-Disposition: attachment;filename="' . $filename . '.xls"' ); //"'.$filename.'.xls"
header ( 'Cache-Control: max-age=0' );
$objWriter = PHPExcel_IOFactory::createWriter ( $objPHPExcel, 'Excel5' ); //在内存中准备一个excel2003文件
ob_end_clean();//清除缓冲区,避免乱码
$objWriter->save ( 'php://output' );
?>

上面先定好.xls模板,再放入数据的例子,很实用

http://blog.sina.com.cn/s/blog_632d132c0102vyw0.html  用代码写模板

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,983
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,500
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,344
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,127
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,761
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,838