php程序 导出表格文件后缀,PHPExcel生成Excel文件---提示导出文件或者文件扩展名不一致,或导出的文件或文件扩展名无效...

$data = Db::name('shop_cart')->where('phone','15555555555')->select();

$objPHPExcel = new PHPExcel();//实例化PHPExcel类 等同于在桌面上新建一个Excel表格

$objSheet = $objPHPExcel->getActiveSheet();//获得当前活动sheet的操作对象

$objSheet->setTitle('demo');//给当前活动sheet设置名字

$objSheet->setCellValue("A1","序号")->setCellValue("B1","产品编号");

$objSheet->setCellValue("C1","产品名称")->setCellValue("D1","产品规格");

$objSheet->setCellValue("E1","浓度")->setCellValue("F1","原价");

$objSheet->setCellValue("G1","优惠价")->setCellValue("H1","货期");

$objSheet->setCellValue("I1","有效期")->setCellValue("J1","批次号");

$objSheet->setCellValue("K1","供货商")->setCellValue("L1","数量");

$objSheet->setCellValue("M1","金额")->setCellValue("N1","备注");

$j = 2;

foreach($data as $key => $val){

if($val['good_stock'] > 50){

$val['good_stock'] = '有货';

}else if($val['good_stock'] < 50 && $val['good_stock'] > 50){

$val['good_stock'] = '缺货';

}else{

$val['good_stock'] = '暂无';

}

$val['good_indate'] = date('Y-m-d',$val['good_indate']);

$objSheet->setCellValue("A".$j,$key+1)->setCellValue("B".$j,$val['good_num'])->setCellValue("C".$j,$val['good_name'])->setCellValue("D".$j,$val['good_spe'])->setCellValue("E".$j,$val['good_standard'])->setCellValue("F".$j,$val['normal_price'])->setCellValue("G".$j,$val['member_price'])->setCellValue("H".$j,$val['good_stock'])->setCellValue("I".$j,$val['good_indate'])->setCellValue("J".$j,$val['good_batch'])->setCellValue("K".$j,$val['company'])->setCellValue("L".$j,$val['good_count'])->setCellValue("M".$j,$val['good_subtotal'])->setCellValue("N".$j,'');

$j++;

}

ob_end_clean();//清除缓冲区,避免乱码

header('Content-Type: application/vnd.ms-excel');

header('Content-Disposition: attachment;filename="links_out.xls"');

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

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');

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

之前怎么做下载下来的文件都是错误格式的。本来就对Excel文件不熟悉,不怎么用,结果就在2003跟2007之间晕了,其实写的没错,

只是没有清除缓冲区

ob_end_clean();

,所以才会提示导出文件或者文件扩展名不一致,或导出的文件或文件扩展名无效,现在Excel5是没问题了

再说Excel2007的,之前一直提示错误,header头跟文件名设置的格式都对还是提示错误,然后再最后加了一条exit;成功不提示了,

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

header('Content-Disposition: attachment;filename="01simple.xlsx"');

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

exit;

完美输出;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值