专注WEB开发 分享经验,沉淀知识

thinkphp利用PHPExcel导出数据实践

 作者:chenxing  时间:2018-01-28 17:46  阅读:6270  评论:

以上就是比较常见也非常简单的phpexcle数据到出方式。

下面是我利用PHPExcel导出数据到excel的一次实践。

第一步,当然是到PHPExcel官网去下载phpexcel插件,将其放到thinkphp的vendor目录下。

第二,将到入数据的具体逻辑封装到工具类中。具体逻辑代码如下:

class UntilLogic
{
    public function phpExcelList($field, $list, $title='文件')
    {
        vendor('phpExcel.PHPExcel');
        $objPHPExcel = new \PHPExcel();
        $objWriter = new \PHPExcel_Writer_Excel5($objPHPExcel); //设置保存版本格式
        foreach ($list as $key => $value) {
            foreach ($field as $k => $v) {
                if ($key == 0) {
                    $objPHPExcel->getActiveSheet()->setCellValue($k . '1', $v[1]);
                }
                $i = $key + 2; //表格是从2开始的
                $objPHPExcel->getActiveSheet()->setCellValue($k . $i, $value[$v[0]]);
            }

        }
        header("Pragma: public");
        header("Expires: 0");
        header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
        header("Content-Type:application/force-download");
        header("Content-Type:application/vnd.ms-execl");
        header("Content-Type:application/octet-stream");
        header("Content-Type:application/download");;
        header('Content-Disposition:attachment;filename='.$title.'.xls');
        header("Content-Transfer-Encoding:binary");
//        $objWriter->save($title.'.xls');
        $objWriter->save('php://output');
    }
}

第三步,读取需要下载数据,和组合excel数据标题$field参数,直接调用第二步的方法。

    public function outExcelRecharge() {
        $where = "1=1";
        $data       = $dbEngin->field('transactions.*,u.name as uname, k.name as kname')->where($where)->order('id desc')->select();
        foreach ($data as $key => $value) {
            $data[$key]['price'] = number_format($data[$key]['price']/100,2);
            $data[$key]['uname'] = filterEmoji($value['uname']);
        }
        $field = array(
            'A' => array('id', 'ID'),
            'B' => array('user_id', '用户ID'),
            'C' => array('uname', '用户名称'),
            'D' => array('created', '时间'),
            'E' => array('order_id', '订单号'),
            'F' => array('price', '金额(元)'),
            'G' => array('coins', '充值金币数'),
            'H' => array('device_id', '设备ID'),
            'I' => array('ktv_id', 'ktvID'),
            'J' => array('kname', 'ktv名称'),
            'K' => array('status', '状态(paid:已付款,refunded:已退款,pending:处理中)')
        );
        $until = new UntilLogic();
        $until->phpExcelList($field, $data, '充值列表_' . date('Y-m-d'));
    }

以上就是比较常见也非常简单的phpexcle数据到出方式。

除特别注明外,本网站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/118.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

一年时间又回到这里

 2019-07-27 16:54  38

PHP字符串转数组的三种场景

 2018-05-05 01:32  171

PHP如何遍历字符串?

 2018-05-04 00:56  744

api接口常见的安全问题和解决方案

 2018-05-03 23:20  685

 最新评论

 pagenoname: 08月24日 18:51
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 iceyxm: 05月16日 15:00
谜一样的问题,我也遇到了,能改的权限都改了,文件目录属主也改了,然而并没有作用
来源: thinkphp5的mkdir() Permission denied问题探讨
 potatog: 03月27日 15:02
厉害了厉害了,搞了半天我,
来源: thinkphp利用PHPExcel导出数据实践
 aaa: 02月10日 17:02
受教
来源: thinkphp如何有效的设置session过期时间
 风格: 01月17日 09:35
我也是没解决
来源: thinkphp5的mkdir() Permission denied问题探讨
 小胡: 01月14日 14:28
非常感谢!使用非常便捷~
来源: thinkphp利用PHPExcel导出数据实践