PHPExcel导出excel表格

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');
        }
    }
}

posted @ 2017-08-22 21:08  tatasix  阅读(443)  评论(0编辑  收藏  举报