zoukankan      html  css  js  c++  java
  • thinkphp5.1导出excel文件第三方类库运用

      若没安装请到:链接地址 https://www.phpcomposer.com/这里安装 composer 

    安装过的,cmd切换到项目根目录运行:composer require phpoffice/phpexcel

    然后等待一会

    说明装成功了。

    然后在用到的控制器或者文件中引用

    命名空间

    use PHPExcel;//tp5.1用法
    use PHPExcel_IOFactory;

    在用到的方法里直接调用

    $objPHPExcel=new PHPExcel();
    $objPHPExcel->setActiveSheetIndex(0);
    // 设置列的宽度
    $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(25);
    $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(25);
    $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(25);
    // 设置表头
    $objPHPExcel->getActiveSheet()->SetCellValue('A1', '订单号');
    $objPHPExcel->getActiveSheet()->SetCellValue('B1', '标题');
    $objPHPExcel->getActiveSheet()->SetCellValue('C1', '金额');
    //$objPHPExcel->getActiveSheet()->getStyle('A2')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
    //存取数据
    $num = 2;
    foreach ($data as $k => $v) {
    $objPHPExcel->getActiveSheet()->SetCellValue('A' . $num, ' '.$v['order_no']); //防止订单号过长变成科学计算问题所以在订单号前拼接空字符,转化为字符串。 ' '.$v['order_no']

    $objPHPExcel->getActiveSheet()->SetCellValue('B' . $num, $v['title']);

    $objPHPExcel->getActiveSheet()->SetCellValue('C' . $num, $v['finance_money']);
    $num++;
    }
    // 文件名称
    $fileName = "订单信息" . date('Y-m-d', time()) . rand(1, 1000);
    $xlsName = iconv('utf-8', 'gb2312', $fileName);
    $objPHPExcel->getActiveSheet()->setTitle('sheet'); // 设置工作表名
    $objWriter = new PHPExcel_Writer_Excel5($objPHPExcel); //下载 excel5与excel2007
    ob_end_clean(); // 清除缓冲区,避免乱码
    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;charset=UTF-8");
    header("Content-Type:application/octet-stream");
    header("Content-Type:application/download");
    header("Content-Disposition:attachment;filename=" . $xlsName . ".xls");
    header("Content-Transfer-Encoding:binary");
    $objWriter->save("php://output");

  • 相关阅读:
    pytest实现参数化(@pytest.mark.parametrize)
    pytest标记测试用例为预期失败(@pytest.mark.xfail)
    pytest标记跳过某些测试用例不执行
    pytest的conftest.py配置
    pytest之fixture使用
    模拟赛42 题解
    模拟赛41 题解
    一些可能永远用不到的性质
    补锅
    骗分杂谈
  • 原文地址:https://www.cnblogs.com/xinyixuan/p/11327417.html
Copyright © 2011-2022 走看看