if(!function_exists('exportExcel')){
    //导出excel文件
    function exportExcel($datas, $save_method='http', $save_path=''){
        set_time_limit(0);
        error_reporting(E_ALL);
        ini_set('display_errors', TRUE);
        ini_set('display_startup_errors', TRUE);
        $excel_title = '箱子详情列表'.date('YmdHis',time());
        $code = $datas['code'];
        $totalBox = $datas['totalBox'];
        $totalPackages = $datas['totalPackages'];
        $totalWeight = $datas['totalWeight'];
        $data = $datas['data'];
        require_once ROOT_PATH.'/Classes/PHPExcel.php';
        $objPHPExcel = new PHPExcel();
        $objPHPExcel->getProperties()
            ->setCreator("Maarten Balliauw")
            ->setLastModifiedBy("Maarten Balliauw")
            ->setTitle("Office 2007 XLSX Test Document")
            ->setSubject("Office 2007 XLSX Test Document")
            ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
            ->setKeywords("office 2007 openxml php")
            ->setCategory("Test result file");
        $row = array('A','B','C','D','E','F','G','H');
        // 设置列宽
        $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(12);
        $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(23);
        $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(10);
        $objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(18);
        $objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(22);
        $objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(23);
        $objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(12);
        $objPHPExcel->getActiveSheet()->getColumnDimension('H')->setWidth(15);
        $styleThinBlackBorderOutline = array(
            'borders' => array (
                'outline' => array (
                    'style' => PHPExcel_Style_Border::BORDER_THIN,
                    'color' => array ('argb' => 'FF000000'),                                    ),
            ),
        );
        for($i=0;$i<count($row);$i++){
            //设置边框
            for ($a = 1; $a < 4; $a++) {
                $objPHPExcel->getActiveSheet()->getStyle($row[$i] . $a)->applyFromArray($styleThinBlackBorderOutline);
            }
            //设置居中
            for($j=1;$j<500;$j++){
                $objPHPExcel->getActiveSheet()->getStyle($row[$i].$j)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::VERTICAL_CENTER);
                $objPHPExcel->getActiveSheet()->getStyle($row[$i].$j)->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
            }
            //设置背景色
            $objPHPExcel->getActiveSheet(0)->getStyle($row[$i].'1')->getFill()->setFillType(\PHPExcel_Style_Fill::FILL_SOLID);
            $objPHPExcel->getActiveSheet(0)->getStyle($row[$i].'1')->getFill()->getStartColor()->setARGB('00FFFF00');
            $objPHPExcel->getActiveSheet(0)->getStyle($row[$i].'2:'.$row[$i].'3')->getFill()->setFillType(\PHPExcel_Style_Fill::FILL_SOLID);
            $objPHPExcel->getActiveSheet(0)->getStyle($row[$i].'2:'.$row[$i].'3')->getFill()->getStartColor()->setARGB('00DBE5F1');
            //设置换行
            $objPHPExcel->getActiveSheet()->getStyle($row[$i].'2')->getAlignment()->setWrapText(true);
        }
        // 设置行高
        $objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight(28);
        $objPHPExcel->getActiveSheet()->getRowDimension('2')->setRowHeight(66);
        //定义表的前三行
        $objPHPExcel->getActiveSheet()
            ->mergeCells('A1:B1')
            ->mergeCells('C1:D1')
            ->mergeCells('E1:F1')
            ->mergeCells('G1:H1')
            ->mergeCells('B2:B3')
            ->mergeCells('C2:C3')
            ->mergeCells('H2:H3')
            ->mergeCells('G2:G3');
        $objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue('A1', '客户代码 Code:')
            ->setCellValue('C1', $code)
            ->setCellValue('E1', '日期 Date:')
            ->setCellValue('G1', date('Y-m-d H:i:s',time()))
            ->setCellValue('A2', '总箱数:'.$totalBox."\n".'Total box')
            ->setCellValue('A3', '箱号')
            ->setCellValue('B2', '转运单号'."\n".'Tracking Number')
            ->setCellValue('C2', '订单号')
            ->setCellValue('D2', '总包裹数:'.$totalPackages."\n".'Total Packages')
            ->setCellValue('D3', '包裹重量(g)')
            ->setCellValue('E2', '总箱重(kg):'.$totalWeight."\n".'Total Weight')
            ->setCellValue('E3', '箱重(kg)')
            ->setCellValue('F2', '总箱体积重'."\n".'(长*宽*高cm/5000)')
            ->setCellValue('F3', '箱体积(长*宽*高cm)')
            ->setCellValue('G2', '头程'."\n".'发货方式')
            ->setCellValue('H2', '跟踪号'."\n".'Tracking Number');
        //处理后面的逻辑
        //当前所在的行数
        $num = 4;
        foreach($data as $k => $v){
            //具体订单个数
            $len = count($v);
            $mergeLen = $num + $len-4;
            $objPHPExcel->getActiveSheet()
                ->mergeCells('E'.$num.':E'.$mergeLen)
                ->mergeCells('F'.$num.':F'.$mergeLen)
                ->mergeCells('G'.$num.':G'.$mergeLen)
                ->mergeCells('H'.$num.':H'.$mergeLen);
            $objPHPExcel->setActiveSheetIndex()
                ->setCellValue('A'.$num, $v['boxId'])
                ->setCellValue('E'.$num, $v['weightss'])
                ->setCellValue('G'.$num, $v['carrier_company']);
            for($i=0;$i<$len-3;$i++){
                $objPHPExcel->setActiveSheetIndex()
                    ->setCellValue('A'.$num, $v['boxId'])
                    ->setCellValueExplicit('B'.$num, $v[$i]['tracknumber'],PHPExcel_Cell_DataType::TYPE_STRING)
                    ->setCellValue('C'.$num, $v[$i]['ebay_id'])
                    ->setCellValue('D'.$num, $v[$i]['weight']);
                $num++;
            }
        }
        $objPHPExcel->getActiveSheet()->setTitle($excel_title);
        $objPHPExcel->setActiveSheetIndex(0);
        $filename = $excel_title.'.xls';
        if($save_method == 'file'){
            //保存到文件
            $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
            $full_path = $save_path.$filename;
            //本地使用,线上注释
            //$full_path = iconv('utf-8', 'gbk//IGNORE', $full_path);
            if(is_file($full_path)) unlink($full_path);
            $objWriter->save($full_path);
            return $full_path;
        }else{
            ob_end_clean();
            //直接在浏览器输出
            header('Content-Type: application/vnd.ms-excel');
            header("Content-Disposition: attachment;filename={$filename}");
            header('Cache-Control: max-age=0');
            $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
            $objWriter->save('php://output');
        }
    }
}

PHPExcel导出excel表格的更多相关文章

  1. php:PHPExcel导出excel表格

    一.动态生成的内容如何能当成文件来下载呢? 方法:1.将Content-Type设置成application/octet-stream就可以了,即[header('Content-Type: appl ...

  2. PHPEXCEL导出excel表格中长数字文本自动转为科学计数法的解决办法

    方法一:前面加空格 $objActSheet->setCellValue('A1', ' '.'330602198804224688'); 方法二: $objActSheet->setCe ...

  3. tp5.0 composer下载phpexcel 实现导出excel 表格

    tp5.0 composer下载phpexcel 实现导出excel 表格 1.在下载好的tp5.0 框架里面使用 composer 下载phpexcel 的插件 composer require p ...

  4. PHP导入导出excel表格图片(转)

    写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wp ...

  5. php header函数导出excel表格

    推荐一个除了用PHPExcel导出表格之外的另外一种比较简单不需要引入类文件的表格导入方法——header()导出excel表格. 导出表格的步骤封装成了方法,以便于重复使用,代码如下: /** * ...

  6. PHP导入导出excel表格图片的代码和方法大全

    基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件 ...

  7. java中使用jxl导出Excel表格详细通用步骤

    该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入s ...

  8. .NET环境下导出Excel表格的两种方式和导入两种类型的Excel表格

    一.导出Excel表格的两种方式,其中两种方式指的是导出XML数据类型的Excel(即保存的时候可以只需要修改扩展名为.xls)和真正的Excel这两种. using System; using Sy ...

  9. java导出excel表格

    java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...

随机推荐

  1. tp框架-----Model模型层

    1.Model模型层是用来做什么的呢? 主要是用来做操作数据库访问的.也就说明TP框架自带了一种访问数据库的方式,使用的是Model模型. 2.Model模型怎样使用呢? 要使用Model模型层访问数 ...

  2. [基础架构]PeopleSoft都有哪些进程运行在进程服务器上

    PSPRCSRV:(PSPRCSRV.EXE) 该进程负责启动所有服务进程. 每隔15s,该进程就会去看进程调度器中是否有需要运行的进程请求.如果没有需要运行的则sleep15s,然后再次检查. 如果 ...

  3. C#.NET 中visual studio生成的.pdb/ .vshost.exe/ .vshost.exe.manifest文件是什么

      pdb文件: 英文全称:Program Database File 中文全称:程序数据库 文件 Debug里的PDB是full,保存着调试和项目状态信息.有断言.堆栈检查等代码.可以对程序的调试配 ...

  4. STL—内存的配置与释放

    上一篇我们介绍了STL对象的构造与析构,这篇介绍STL内存的配置与释放. STL有两级空间配置器,默认是使用第二级.第二级空间配置器会在某些情况下去调用第一级空间配置器.空间配置器都是在allocat ...

  5. 新浪微博的OAuth2认证过程

    1. 创建应用 在weibo.com上申请一个应用,获取app key和app secret, 填写redirect uri 2. 获取code 通过在浏览器访问 https://api.weibo. ...

  6. Java后端开发书架

    本人摘录于江南白衣文章,文章地址:http://calvin1978.blogcn.com/articles/javabookshelf.html 书架主要针对Java后端开发. 3.0版把一些后来买 ...

  7. 20170717_python_爬虫_网页数据解析_BeautifulSoup_数据保存_pymysql

    上午废了老大劲成功登陆后,下午看了下BeautifulSoup和pymysql,晚上记录一下 自己电脑装的sublime,字体颜色竟然拷贝不下来 - - 写的过程中遇到了很多问题: 1.模拟登陆部分 ...

  8. SetConsoleScreenBufferSize 函数--设置控制台屏幕缓冲区大小

    SetConsoleScreenBufferSize函数 来源:https://msdn.microsoft.com/en-us/library/windows/desktop/ms686044(v= ...

  9. (转)每天一个linux命令(8):cp 命令,复制文件和文件夹

    场景:自动部署脚本中为了部署方便,将配置文件放在服务器端,每次部署都使用服务端的配置文件覆盖上传上去的配置文件. cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一. 一般情况下,she ...

  10. [Tyvj 1728] 普通平衡树

    大名鼎鼎的板子题w 照例先贴题面 Describtion 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3. ...