我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章主要介绍“如何使用PHP原生来导出Excel和CSV文件”,在日常操作中,相信很多人在如何使用PHP原生来导出Excel和CSV文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用PHP原生来导出Excel和CSV文件”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

                           

PHP原生导出Excel

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

导出伪代码如下:

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);}

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

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

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

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

对于日期格式设置 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

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

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

常用的也就上面这些了 这里还有个 常用列表 不过他使用的关键字是 mso-number-format 我尝试了下 style 中使用 mso-number-formatvnd.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原生来导出Excel和CSV文件”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

这篇文章主要介绍“如何使用PHP原生来导出Excel和CSV文件”,在日常操作中,相信很多人在如何使用PHP原生来导出Excel和CSV文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用PHP原生来导
2023-06-20

如何使用java导出Excel文件

如何使用java导出Excel文件?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java导出Excel通用方法的实例详解Java导出Excel通用方法,只需要一
2023-05-31

使用java如何实现大量导出excel文件

使用java如何实现大量导出excel文件?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.传统的导出方式会消耗大量的内存,2003每个sheet页最多65536条数据,200
2023-05-31

在Java Web中Excel文件如何使用POI实现导出

在Java Web中Excel文件如何使用POI实现导出?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。采用Spring mvc架构:Controller层代码如下@Cont
2023-05-31

如何使用JavaScript把页面上的表格导出为Excel文件

本篇内容主要讲解“如何使用JavaScript把页面上的表格导出为Excel文件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用JavaScript把页面上的表格导出为Excel文件”吧!
2023-06-04

如何使用Python将MySQL数据库中的数据导出为CSV文件?(Python环境下如何将MySQL数据导出为CSV格式?)

使用Python将MySQL数据库数据导出为CSV格式的过程包括:连接数据库,执行SELECT查询获取数据,创建CSV文件,逐行写入数据,最后关闭连接。通过mysql.connector库连接数据库,使用cursor对象执行查询,利用csv模块创建CSV文件并写入数据,可轻松实现MySQL数据的导出。
如何使用Python将MySQL数据库中的数据导出为CSV文件?(Python环境下如何将MySQL数据导出为CSV格式?)
2024-04-02

DataGrip 如何导出和恢复整个数据库数据,使用单个 SQL 文件

DataGrip 如何导出和恢复整个数据库数据,使用单个 SQL 文件 之前一直用 Navicat 来处理数据库数据,整个导出导入等,用习惯了之后,再用 DataGrip 总找不到对应操作的地方。比如数据库的整个导入导出,我就找了半天才找到
2023-08-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录