• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 如何使用PHP原生来导出Excel和CSV文件

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

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了PHP原生导出Excel,PHP导出CSV等相关知识,希望对您有所帮助

PHP原生导出Excel

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

导出伪代码如下:

/** * 导出excel文件 * * @param string $excelFileName 导出的文件名 * @param array $title excel的标题列 * @param array $data 导出的数据 */public function exportExcel($excelFileName, $title, $data){    $str = "<html xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\nxmlns:x=\"urn:schemas-microsoft-com:office:excel\"\r\nxmlns=\"http://www.w3.org/TR/REC-html40\">\r\n<head>\r\n<meta http-equiv=Content-Type content=\"text/html; charset=utf-8\">\r\n</head>\r\n<body>";    $str .="<table border=1 align=center cellpadding=0 cellspacing=0>";    // 拼接标题行    $str .= '<tr style="height:25px;font-size:13px;font-weight: bold;">';    foreach ($title as $key => $val) {        $str .= '<td>'.$val.'</td>';    }    $str .= '</tr>';    // 拼接数据    foreach ($data as $key => $val) {        $str .= '<tr style="text-align: left;height:25px;font-size:13px;">';        foreach ($val as $v) {            if (is_numeric($v) && $v > 100000000) {                $str .= "<td style='vnd.ms-excel.numberformat:@'>".$v."</td>";            } elseif (is_numeric($v) && preg_match('/^[0-9]+(\.[0-9]{2})+$/', $v)) {                // 是两位小数的保留2位显示                $str .= "<td style='vnd.ms-excel.numberformat:0.00'>".$v."</td>";            } 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 .= "<td style='vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss'>".$v."</td>";            } else {                $str .= "<td>".$v."</td>";            }        }        $str .= "</tr>\n";    }    $str .= "</table></body></html>";    // 实现文件下载    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文件。

代码如下:

/** * 导出CSV标准文件 * * @param string $fileName 导出的文件名 * @param array $title 标题列 * @param array $data 导出的数据 */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();}


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何使用PHP原生来导出Excel和CSV文件

相关文章

  • 2022-04-29Bootstrap中switch的用法是什么
  • 2022-04-29利用curl函数抓取网站数据,仿造IP+伪造来源+防屏蔽
  • 2022-04-29如何利用HTML5 canvas旋转图片?(实例演示)
  • 2022-04-29PHP中的__callStatic函数如何使用
  • 2022-04-29如何用python正则表达式匹配字符串?
  • 2022-04-29小程序中怎么进行父子组件传值和方法调用?(方法汇总)
  • 2022-04-29Photoshop绘制漂亮的粉色立体心形教程
  • 2022-04-29Discuz3.4特殊字符乱码解决方案
  • 2022-04-29Photoshop制作绿色风格金属立体字教程
  • 2022-04-29CorelDraw制作手提袋和礼品盒

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • PhotoShop制作简单的炫光残破文字效果教程
    • 10个超级有用的PHP代码片段(建议收藏)
    • PhotoShop CS6简单制作细线格子纹理字效教程
    • 教你5个让Vue3开发更顺畅的知识点
    • 微信小程序wx.request请求数据报错
    • PHP网站常见安全漏洞,及相应防范措施总结
    • Centos下Laravel访问页面出现空白怎么办?
    • php怎么去除重复的值
    • 使用18小时快速搜索引擎排名的后果
    • PHP开发api接口验证实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有