栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

一文讲解如何使用PHP原生来导出Excel和CSV文件

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

一文讲解如何使用PHP原生来导出Excel和CSV文件

PHP原生导出Excel

导出的原理其实就是通过设置Header头告诉浏览器用excel的格式来解析读取,然后通过生成HTML表格来输出内容。对于单元格的合并其实就和操作HTML表格的合并是一样的了,支持样式的属性和字段,同时还可以操作 td 的样式来控制单元格。

导出伪代码如下:

public function exportExcel($excelFileName, $title, $data)
{
    $str = "rnrnrnrn";
    $str .="";
    // 拼接标题行
    $str .= '';
    foreach ($title as $key => $val) {
 $str .= '';
    }
    $str .= '';
    // 拼接数据
    foreach ($data as $key => $val) {
 $str .= '';
 foreach ($val as $v) {
     if (is_numeric($v) && $v > 100000000) {
  $str .= "";
     } elseif (is_numeric($v) && preg_match('/^[0-9]+(.[0-9]{2})+$/', $v)) {
  // 是两位小数的保留2位显示
  $str .= "";
     } elseif (preg_match('/^[0-9]{4}-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1]) (0[0-9]|1[0-9]|2[0-4]):(0[0-9]|[1-5][0-9]):(0[0-9]|[1-5][0-9])$/', $v)) {
  // 是日期
  $str .= "";
     } else {
  $str .= "";
     }
 }
 $str .= "n";
    }
    $str .= "
'.$val.'
".$v."".$v."".$v."".$v."
"; // 实现文件下载 header("Content-Type: application/vnd.ms-excel; name='excel'"); header("Content-type: application/octet-stream"); header("Content-Disposition: attachment; filename=" . $excelFileName); header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); header("Expires: 0"); exit($str); }

其中我简单写了些样式和一些正则校验,不用可以删除。主要说一下一些单元格的格式化说明。

以上的导出会有几个常见的问题:

1.对于身份证号,手机号等过大的数字 显示的时候会用科学计数法显示。如果不介意字符串显示的话可以通过设置 td 的样式来控制 style='vnd.ms-excel.numberformat:@' 这样表示用文本的方式来显示

2.对于数字如果需要保留小数位可以设置 style='vnd.ms-excel.numberformat:0.00' 需要保留几位小数就写几个0,需要注意一点如果你传入的值比保留的小数位多,那么值会被四舍五入。比如传入的是 87.98 而设置的保留小数位是 vnd.ms-excel.numberformat:0.0 那么会显示成 88.0

3.对于日期格式设置 style='vnd.ms-excel.numberformat:yyyy-mm-dd hh:mm:ss' 其中空格、冒号等都需要转义。如果使用的是HTML里的空格字符表辅助出来会有些不一样,上面是常用的格式组合,可以自己做转换。还有一些别的转换 style='vnd.ms-excel.numberformat:"Short Date"' 这个会显示成 2019/7/1; style='vnd.ms-excel.numberformat:"Medium Date"' 会显示成 1-Jul-19

4.百分比显示。 要显示百分比的话 可以使用格式 style='vnd.ms-excel.numberformat:0%' 有一点需要注意显示的时候会把你的值放大100倍。也就是说假如你想显示成 2% 你传递进来的值需要是 0.02

5.千位分隔符。如果需要数字显示带千位分隔符可以设置 style='vnd.ms-excel.numberformat:#,###' 比如 123456 就会显示成 123,456

常用的也就上面这些了 这里还有个 常用列表 不过他使用的关键字是 mso-number-format 我尝试了下 style 中使用 mso-number-format 和 vnd.ms-excel.numberformat 都可以。

PHP导出CSV

CSV文件其实是一种通用的文件,有时也被叫做文本文件。因此导出的CSV数据报文件不能设置单元格的样式,而xls属于二进制的文件需要使用Excel之类的工具才能打开。如果没有硬性要求导出这种速度更快,我看阿里云上的一些导出都是CSV格式,但是我们这边的需要非要excel文件.

伪代码如下:

function exportCsv($fileName, $title, $data)
{
    // 清空输出流,防止有别的信息
    ob_end_clean();
    // 打开一个输出流
    ob_start();
    // 设置header信息
    header("Content-Type: text/csv");
    header("Content-Disposition:filename=". $fileName);
    // 打开文件流
    $fileHandle = fopen('php://output', 'w');
    //转码 防止乱码
    fwrite($fileHandle, chr(0xEF).chr(0xBB).chr(0xBF));
    // 先把标题写进去
    fputcsv($fileHandle, $title);
    $index = 0;
    foreach ($data as $item) {
 // 每2000条释放一次资源
 if ($index == 2000) {
     $index = 0;
     ob_flush();
     flush();
 }
 $index++;
 fputcsv($fileHandle, $item);
    }
    // 释放资源
    ob_flush();
    flush();
    ob_end_clean();
}

推荐学习:《PHP视频教程》

以上就是一文讲解如何使用PHP原生来导出Excel和CSV文件的详细内容,更多请关注考高分网其它相关文章!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/262367.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号