PHP下载excel表格

public static function downXls($data, $keynames, $headers, $name = 'dataxls', $convert = false, $xmlv = false)
    {
        $xls[] = "<html xmlns:x=\"urn:schemas-microsoft-com:office:excel\"><meta http-equiv=content-type content=\"text/html; charset=UTF-8\"><body><table border='1'>";
        if ($headers) {
            $xls[] = $headers;
        }
        $xls[] = "<tr><td>ID</td><td>" . implode("</td><td>", array_values($keynames)) . '</td></tr>';
        $index = 0;
        foreach ($data As $o) {
            $line = [++$index];
            foreach ($keynames AS $k => $v) {
                $line[] = $o[$k];
            }
            $xls[] = '<tr><td>' . implode("</td><td x:str>", $line) . '</td></tr>';
        }
        $xls[] = '</table></body></html>';
        $xls   = join("\r\n", $xls);
        if ($xmlv) {
            $filename = $name . '.xlsx';
        }//excel2007+版本
        else {
            $filename = $name . '.xls';
        }//excel2003版本
        if ($convert) {
            //修正文件名在某些浏览器当中乱码的问题
            $ua               = $_SERVER["HTTP_USER_AGENT"];
            $encoded_filename = urlencode($filename);
            $encoded_filename = str_replace("+", "%20", $encoded_filename);
            if (preg_match("/MSIE/", $ua)) {
                header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');
            } else {
                if (preg_match("/Firefox/", $ua)) {
                    header('Content-Disposition: attachment; filename*="utf8\'\'' . $filename . '"');
                } else {
                    header('Content-Disposition: attachment; filename="' . $filename . '"');
                }
            }
        } else {
            header('Content-Disposition: attachment; filename="' . $filename . '"');
        }

        die(mb_convert_encoding($xls, 'UTF-8', 'UTF-8'));
    }

$list=[
            ['id'=>2,
                'name'=>'汪杨',
                'address'=>'湖南'
            ],
            ['id'=>2,
                'name'=>'汪杨',
                'address'=>'18612345678'
            ]

        ];
        $header=[
            'id'=>'ID',
            'name'=>'姓名',
            'address'=>'地址'
        ];
        Excel::downXls($list,$header,'aa','aa11');

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值