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表格
时间: 2024-10-20 19:06:49
PHPExcel导出excel表格的相关文章
基于PHPExcel 导出Excel表格
下载PHPExcel源码:http://phpexcel.codeplex.com/ 只要 PHPExcel_1.8.0_doc\Classes 目录下所有文件即可 <?php require_once("../db_config.php"); require_once("Classes/PHPExcel.php"); include("Classes/PHPExcel/IOFactory.php"); //$id=$_GET[
PHP导入导出excel表格图片(转)
写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wps等进行word等的生成之类的文章 )但是在读的时候,只用过一种,具体是什么忘了,要回去翻代码了.基本上导出的文件分为两种:1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件.优
PHPExcel导出Excel文件
error_reporting(0); require_once 'phpexcel/PHPExcel.php'; require_once 'phpexcel/PHPExcel/IOFactory.php'; $objPHPExcel = new PHPExcel(); $objPHPExcel->getProperties()->setCreator("BillHong") ->setLastModifiedBy("BillHong")//创建
【PHP】PHP使用PHPExcel生成Excel表格文件(附带随机生成英文名函数)
[PHP]PHP使用PHPExcel生成Excel表格文件(附带随机生成英文名函数) 前言 由于业务需要,我们需要从业务中汇总数据,并生成Excel文件. 思路是这样的 PHP要导出Excel表格文件->找一个好用的第三方库吧->在Composer的Packages里找一个吧->PHPExcel这么多收藏,就它了! PHPExcel 概述 PHPExcel is a library written in pure PHP and providing a set of classes th
PHPExcel导出excel
如果导出中文时出现乱码,可以尝试将字符串转换成gb2312,例如下面就把$yourStr从utf-8转换成了gb2312: $yourStr = mb_convert_encoding("gb2312", "UTF-8", $yourStr); 总结 php导出Excel php导入Excel PhpExcel使用说明 PhpExcel使用手册 1:第一推荐无比风骚的PHPExcel,官方网站: http://www.codeplex.com/PHPExcel 导入
原生JavaScript 导出excel表格(兼容ie和其他主流浏览器)
因同事的需求是想前端导出excel表格,网上找了一些demo,自己修改了一下,可能以后会用到,记录下来吧,兼容ie和一些主流浏览器,ie可能会报错,原因参考 这里,edge 浏览器还没有办法导出,正在尝试... <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>table 导出excel表格</title>
PHPExcel-1.8.1导入、导出Excel表格
仅留作记录使用: /** * 读取文件方案一 */ public function readExcel() { require_once VENDOR_PATH . 'PhpExcel/PHPExcel/IOFactory.php'; // 循环遍历数据 $objReader = \PHPExcel_IOFactory::createReader('Excel2007'); /
java中使用jxl导出Excel表格详细通用步骤
该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入session中备份一份,在调用导出方法时,从session中获取即可, 如果为后台直接导出,直接查询数据库后将结果传入即可,当然也可以在导出Excel方法中查询. 查询方法: // 获取查询结果存入session中 Object resultList = request.getAttr
关于PHPExcel导出Excel时身份证,数字会导出为科学计数的处理方法
原文:关于PHPExcel导出Excel时身份证,数字会导出为科学计数的处理方法 上次在开发一个项目时,用到PHPExcel导出数据,其中有导出身份证等长串数字时导出的Excel中显示为科学计数方式. 这种显示很不人性化而且量多了修改起来也很麻烦. 这是因为Excel处理数字里默认数字太长会转化为科学计数法,处理起来很简单,我们在导出时把数字转为字符串,Excel就不会识别为数字了,也就不会显示为科学计数方式. 我的处理方式是在变量后面加个空格,简单方便. $usercode .= ' '; $