欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

php直接生成.csv后缀文件的excel表格实例

程序员文章站 2022-07-12 20:51:32
...

先了解如何生成后缀为 .csv文件的方法 传送门

   # 数组,调用下面方法然后直接下载
    public function index(){
        $array = [
            ['name' => '张三','age' => 17],
            ['name' => '李四','age' => 18],
            ['name' => '王五','age' => 19],
            ['name' => '麻二','age' => 20],
        ];

        return $this->export_csv($array);

    }

/***
     * 导出下载excel
     * @param [array] $array [要转换excel数组]
     */
    public function export_csv($array){
        $temp = '';
        foreach ($array as $value)
        {
            foreach ($value as $k => $val)
            {
                $value[$k] = iconv('utf-8','gb2312',$value[$k]);
            }

            $temp .= implode(",",$value)."\n"; //用英文“逗号”分开,获取值
        }

        # 获取name,age做标题【这里我没有想到更好的方法,做个flag以便以后更加完善】
        ## 就是要取出 ‘name’,'age' 这两个key
        $keyname = array_keys($array[0])[0] . ',' . array_keys($array[0])[1] ."\n";
        $string  = $keyname. $temp;//拼接

        $filename = date('Ymd').'.csv'; //设置文件名
        header("Content-type:text/csv");
        header("Content-Disposition:attachment;filename=".$filename);
        header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
        header('Expires:0');
        header('Pragma:public');
        echo $string;
    }

最终导出的excel如下:

php直接生成.csv后缀文件的excel表格实例

以上是没有使用类库的生成简单excel方法!

相关标签: excel php