php生成excel到服务器,phpoffice生成文件到服务器指定文件

该代码段展示了如何使用PHP生成Excel文件并将其存储到服务器上,而不是直接通过'php://output'导出。在微信环境中,由于内建浏览器的限制,直接导出会导致下载失败。为了解决这个问题,代码将文件保存到服务器的特定目录,并提供了一个文件名,之后可以通过其他浏览器下载。此外,文件名避免使用中文以防止乱码问题。
摘要由CSDN通过智能技术生成

原代码

/**

* 导出excel信息

* @param string $titles 导出的表格标题

* @param string $keys 需要导出的键名

* @param array $data 需要导出的数据

* @param string $file_name 导出的文件名称

*/

function export_excel($titles = '', $keys = '', $data = [], $file_name = '导出文件' )

{

$objPHPExcel = get_excel_obj($file_name);

$y = 1;

$s = 0;

$titles_arr = str2arr($titles);

foreach ($titles_arr as $k => $v) {

$objPHPExcel->setActiveSheetIndex($s)->setCellValue(string_from_column_index($k). $y, $v);

}

$keys_arr = str2arr($keys);

foreach ($data as $k => $v)

{

is_object($v) && $v = $v->toArray();

foreach ($v as $kk => $vv)

{

$num = array_search($kk, $keys_arr);

false !== $num && $objPHPExcel->setActiveSheetIndex($s)->setCellValue(string_from_column_index($num) . ($y + $k + 1), $vv );

}

}

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

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

exit;

}

/**

* 获取excel

*/

function get_excel_obj($file_name = '导出文件')

{

set_time_limit(0);

vendor('phpoffice/phpexcel/Classes/PHPExcel');

header("Pragma: public");

header("Expires: 0");

header("Cache-Control:must-revalidate, post-check=0, pre-check=0");

header("Content-Type:application/force-download");

header("Content-Type:application/vnd.ms-execl");

header("Content-Type:application/octet-stream");

header("Content-Type:application/download");

header('Content-Disposition:attachment;filename='.iconv("utf-8", "gb2312", $file_name).'.xlsx');

header("Content-Transfer-Encoding:binary");

return new PHPExcel();

}

改代码

function export_excel_ceshi($titles = '', $keys = '', $data = [], $file_name = '导出文件' )

{

vendor('phpoffice/phpexcel/Classes/PHPExcel');

$objPHPExcel = new PHPExcel();

$y = 1;

$s = 0;

$titles_arr = str2arr($titles);

foreach ($titles_arr as $k => $v) {

$objPHPExcel->setActiveSheetIndex($s)->setCellValue(string_from_column_index($k) . $y, $v);

}

$keys_arr = str2arr($keys);

foreach ($data as $k => $v) {

is_object($v) && $v = $v->toArray();

foreach ($v as $kk => $vv) {

$num = array_search($kk, $keys_arr);

false !== $num && $objPHPExcel->setActiveSheetIndex($s)->setCellValue(string_from_column_index($num) . ($y + $k + 1), $vv);

}

}

$writer = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');

$filename = date('YmdHis',time()).$file_name.'.xlsx';

$filename = iconv("utf-8","gb2312",$filename);

$writer->save('upload/file/'.$filename);

return $filename;

exit;

}

微信公众号开发的网页,首先要验证是否是微信打开,而导出excel则只能跳到其他浏览器下载。跳到其他浏览器,则会验证不是微信打开,所以下载失败。

解决办法是,先用微信内置浏览器生成excel文件,存到服务器指定文件夹,返回文件名,再跳转到其他浏览器下载。

所以就不用$objWriter->save('php://output');

改用$writer->save('upload/file/'.$filename);

文件名不要用中文,省的乱码,找不到文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值