• 技术文章 >后端开发 >php教程

    php导出csv格式的Excel文件的实现代码

    不言不言2018-08-18 17:37:42原创1888
    本篇文章给大家带来的内容是关于php导出csv格式的Excel文件的实现代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    效果图

    这里写图片描述

    源码分析

    index.php

    <?php
    require_once "./Export.php";//测试数据
    $headerList= ['列名1','列名2','列名3'];
    $data = [
        ['值1','值2','值3'],
        ['值11','值22','值33'],
        ['值111','值222','值333']
    ];
    $fileName = "测试导出文件名";
    $tmp = ['备份字段1','备份值1','','备份字段2','备份值2'];
    $export = new Export();$result = $export->exportToCsv($headerList,$data,$fileName,$tmp);

    Export.php

    <?php
    class export{
        /**
         * params $headerList 头部列表信息(一维数组) 必传
         * params $data 导出的数据(二维数组)    必传
         * params $filename 文件名称转码 必传
         * params $tmp 备用信息(二维数组) 选传
         * PS:出现数字格式化情况,可添加看不见的符号,使其正常,如:"\t"
         **/
        public function exportToCsv($headerList = [] , $data = [] , $fileName = '' , $tmp = []){
            //文件名称转码
            $fileName = iconv('UTF-8', 'GBK', $fileName);        //设置header头
            header('Content-Type: application/vnd.ms-excel');
            header('Content-Disposition: attachment;filename=' . $fileName . '.csv');
            header('Cache-Control: max-age=0');        //打开PHP文件句柄,php://output,表示直接输出到浏览器
            $fp = fopen("php://output","a");        //备用信息
            foreach ($tmp as $key => $value) {            
            $tmp[$key] = iconv("UTF-8", 'GBK', $value);
            }       
             //使用fputcsv将数据写入文件句柄
            fputcsv($fp, $tmp);        
            //输出Excel列表名称信息
            foreach ($headerList as $key => $value) {            
            $headerList[$key] = iconv('UTF-8', 'GBK', $value);//CSV的EXCEL支持BGK编码,一定要转换,否则乱码
            }        
            //使用fputcsv将数据写入文件句柄
            fputcsv($fp, $headerList);        //计数器
            $num = 0;        
            //每隔$limit行,刷新一下输出buffer,不要太大亦不要太小
            $limit = 100000;       
             //逐行去除数据,不浪费内存
            $count = count($data);        
            for($i = 0 ; $i < $count ; $i++){           
            $num++;            、
            //刷新一下输出buffer,防止由于数据过多造成问题
                if($limit == $num){
                    ob_flush();
                    flush();                
                    $num = 0;
                }            
                $row = $data[$i];            
                foreach ($row as $key => $value) {                
                $row[$key] = iconv('UTF-8', 'GBK', $value);
                }
                fputcsv($fp, $row);
            }
        }
    }

    链接:https://pan.baidu.com/s/1e9BK6l5fY4aDDgYS7CLUig 密码:v120

    相关推荐:

    PHP如何实现模糊查询(图文代码)

    php和ajax怎么实现表格的实时编辑(附代码)

    以上就是php导出csv格式的Excel文件的实现代码的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:PHP 导出
    上一篇:PHP如何实现模糊查询(图文代码) 下一篇:php利用open,fwrite实现导出多种格式的文件(代码)
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 理解php依赖注入和控制反转_php技巧• 分享常见的几种页面静态化的方法_php基础• PHP查询附近的人及其距离的实现方法• PHP编程入门的基本语法知识点总结_php基础• 浅析php中json_encode()和json_decode()_php基础
    1/1

    PHP中文网