php 数据导出并下载,PHP将数据转为EXCEL并导出下载

//引入文件

include_once('PHPExcel.php');

require_once('PHPExcel/Writer/Excel2007.php');

require_once('PHPExcel/Writer/Excel5.php');

include_once('IOFactory.php');

$now = date("Y-m-d-H-i-s");

header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');

header("Content-Disposition:attachment;filename=$now.xlsx");

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

$objExcel = new PHPExcel();

//在网页上预览时要开启,但要关闭头部

//$objWriter = new PHPExcel_Writer_Excel5($objExcel);

//$objWriteHTML = new PHPExcel_Writer_HTML($objExcel);

//在网页上预览时要开启,但要关闭头部

// 设置文档属性

$objExcel->getProperties()->setCreator("Liu Jian fan") // 文档作者

->setLastModifiedBy("Liu Jian fan") // 最后一次修改者

->setTitle("Office 2003 XLS Test Document") // 标题

->setSubject("Office 2003 XLS Test Document") // 主题

->setDescription("Test document for Office 2003 XLS, generated using PHPExcel.") // 备注

->setKeywords("office 2003 openxml php") // 关键字

->setCategory("Test result file"); // 类别

//设置值

$objExcel->getActiveSheet()->setCellValue('a1', "序号");

$objExcel->getActiveSheet()->setCellValue('b1', "用户名");

$objExcel->getActiveSheet()->setCellValue('c1', "性别");

$objExcel->getActiveSheet()->setTitle('11111111');

$objExcel->getActiveSheet() ->setCellValueByColumnAndRow(7, 3, date('Y-m-d h:i:s'));

//循环输出

$arr = array('0'=>array('pid'=>'1','nickname'=>'用户名1','gender'=>'m'), '1'=>array('pid'=>'2','nickname'=>'用户名2','gender'=>'f'));

$i=0;

if(count($arr)){

foreach($arr as $w){

$u1=$i+2;

$objExcel->getActiveSheet()->setCellValue('a'.$u1, $w["pid"]);

$objExcel->getActiveSheet()->setCellValue('b'.$u1, $w["nickname"]);

$gender_arr = array('m'=>'男','f'=>'女');

$objExcel->getActiveSheet()->setCellValue('c'.$u1, $gender_arr[$w["gender"]]);

$i++;

}

}

$objExcel->createSheet(1);

$two = $objExcel->getSheet(1);

$two->setTitle('测试2');

$two -> setCellValue('a5','333333');

// 设置第3行第5列(E3)的值

$two->setCellValueByColumnAndRow(4, 3, date('Y-m-d h:i:s'));

//合并单元格

$two->mergeCells("a1:f2");

$two -> setCellValue('a1','教育技术学');

// 设置第一行标题的属性

$two->getRowDimension(1)->setRowHeight(100) // 行高

->setVisible(true); // 是否可见,默认为true

//->setRowIndex(8) // 变更行号为6

// ->setOutlineLevel(5); // 优先级别,默认为0,参数必须是0到7

// 设置第F列的属性

// getColumnDimension("F")可以用getColumnDimensionByColumn(5)代替

$two->getColumnDimension("E")//->setWidth(40) // 列宽

//->setColumnIndex("I") // 变更列号为I

//->setVisible(true); // 是否可见

->setAutoSize(true); // 自动适应列宽

// 获取单元格标题第一格的样式对象

$style = $two->getStyle("a1"); // 等价于getStyleByColumnAndRow(1,1)

// 设置该单元格的字体属性

$style->getFont()->setBold(true) // 是否粗体

->setSize(22) // 字号

->setName("Gungsuh") // 字体名,只适用于外文字体

// ->setItalic(true) // 是否斜体

//->setStrikethrough(true) // 是否有删除线

// ->setUnderline(PHPExcel_Style_Font::UNDERLINE_DOUBLEACCOUNTING) // 下划线类型

->getColor()->setARGB(PHPExcel_Style_Color::COLOR_BLUE); // 字体颜色

// 设置该单元格的背景填充属性

$style->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID) // 填充模式

->getStartColor()->setARGB(PHPExcel_Style_Color::COLOR_GREEN); // 背景颜色

// 设置该单元格中数字的格式 针对于第一行

$style->getNumberFormat()->setFormatCode("0.00");

// 设置该单元格中文本对齐方式

$style->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER) // 水平方向

->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); // 垂直方向

//从指定的单元格复制样式信息.

$two->duplicateStyle($style, 'B1:B10');

//设置A5边框

$objStyleS = $two->getStyle('A7');

$objBorderA5 = $objStyleS->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);

$two->duplicateStyle($objStyleS, 'c3:c12');

//输出文件

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

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

//用于在网页上浏览,则注释掉上面的输出

//$objWriteHTML->save("php://output");

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值