利用phpexcel对数据库数据的导入excel(excel筛选)、导出excel
话不多说,请看代码:
');
require_once('../Classes/PHPExcel.php');
require_once("config.php");
require_once("mysql.class.php");
//根据时间生成采购报表
$time=date("a");
$minute=date("i");
$apm="";
if($time=='pm'){
$apm=$time;
$stime=mktime(12,00,00,date('m'),date('d')-1,date('Y'));
$etime=mktime(11,59,59,date('m'),date('d'),date('Y'));
}else{
$apm=$time;
$stime=mktime(12,00,00,date('m'),date('d')-1,date('Y'));
$etime=mktime(11,59,59,date('m'),date('d'),date('Y'));
}
//实例化excel类
$objPHPExcel=newPHPExcel();
////////获取文档信息
////////$objProps=$objPHPExcel->getProperties();
///////print_r($objProps);
///////echo"
";
///////$objProps->setDescription("test_123456");
///////print_r($objProps);
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A5','商品编码')
->setCellValue('B5','货号')
->setCellValue('C5','商品名称')
->setCellValue('D5','采购量');
//设置选定sheet表名
$objPHPExcel->getActiveSheet()->setTitle('祖名');
//设置字体样式
$objPHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setName('Arial')->setSize(25);//////->setUnderline(true);/////->getColor()->setARGB('FFFF0000');///->setBold(true);
//合并单元格给单元格赋值(数值,字符串,公式)
$objPHPExcel->getActiveSheet()->mergeCells('A1:D3')->setCellValue('A1','zhongyi清单');
///////$objPHPExcel->getActiveSheet()->mergeCells('A4:D4')->setCellValue('A4',"=SUM(E4:F4)");
$date_now=date("Y-m-d");
$objPHPExcel->getActiveSheet()->mergeCells('A4:D4')->setCellValue('A4',"采购日期:".$date_now."".$apm."");
//设置单列宽度
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(15);
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(20);//$objPHPExcel->getActiveSheet()->getColumnDimension('G')->setRowHeight(50);/
$objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(44);
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(15);
//大边框样式边框加粗
$lineBORDER=array(
'borders'=>array(
'outline'=>array(
'style'=>PHPExcel_Style_Border::BORDER_THICK,
'color'=>array('argb'=>'000000'),
),
),
);
//表头样式
$head=array(
'font'=>array(
'bold'=>true
),
'alignment'=>array(
'horizontal'=>PHPExcel_Style_Alignment::HORIZONTAL_CENTER,
'vertical'=>PHPExcel_Style_Alignment::VERTICAL_CENTER
),
);
//标题样式
$title=array(
'font'=>array(
'bold'=>true
),
);
//居中对齐
$CENTER=array(
'alignment'=>array(
'horizontal'=>PHPExcel_Style_Alignment::HORIZONTAL_CENTER,
'vertical'=>PHPExcel_Style_Alignment::VERTICAL_CENTER
),
);
//靠右对齐
$RIGHT=array(
'alignment'=>array(
'horizontal'=>PHPExcel_Style_Alignment::HORIZONTAL_RIGHT,
'vertical'=>PHPExcel_Style_Alignment::VERTICAL_CENTER
),
);
//细边框样式
$linestyle=array(
'borders'=>array(
'outline'=>array(
'style'=>PHPExcel_Style_Border::BORDER_THIN,
'color'=>array('argb'=>'FF000000'),
),
),
);
$objPHPExcel->getActiveSheet()->getStyle('A1:D3')->applyFromArray($head);///->getAlignment()->getHorizontal('');///->getBorders()->getTop()->setBorderStyle('');
//->setWrapText(true);自动换行
$objPHPExcel->getActiveSheet()->getStyle('A4:D4')->applyFromArray($RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('A5:D5')->applyFromArray($title);
//填充色
/////$objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->getStartColor()->setARGB('FFFF0000');/
//插入数据
$dsql->Execute('omebrand_list',"selecti.goods_id,sum(`nums`)ASnum,i.name,i.addon,i.price,g.bnasb,i.bnash,
g.goods_id,i.goods_id,i.order_id
FROM`sdb_b2c_order_items`asi,sdb_b2c_goodsasg
WHEREi.order_idin(selectorder_idfromsdb_b2c_orderswherestatus='active'andcreatetimebetween$stimeand$etime)andi.goods_id=g.goods_idandg.cat_id=173GROUPBYh");
$m=0;
unset($re);
while($row=$dsql->GetObject('omebrand_list'))
{$re[$m]=get_object_vars($row);
$m++;
}
$row_count=5;
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A6',12325416541)
->setCellValue('B6',4962132165262)
->setCellValue('C6',121515212515241521)
->setCellValue('D6',96215465415);
foreach($reas$r=>$dataRow){
$baseRow=6;
$row=$baseRow+$r;
$bn=$dataRow[h];
$goods_id=$dataRow[goods_id];
$spec_value="";
$aa=unserialize($dataRow[addon]);
if($aa['product_attr']){
foreach($aa['product_attr']as$arr_special_info){
$spec_value=$arr_special_info['value'];
}
}
preg_match_all('/\\-?\\d+\\.?\\d*/i',$spec_value,$row1);
$num=$row1[0][0];
$all=$num*$dataRow[num];
if($spec_value==''){
$all=$dataRow['num'];
//$prce=$dataRow[price];
}
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A'.$row,$dataRow['b'])
->setCellValue('B'.$row,$bn)
->setCellValue('C'.$row,$dataRow['name'])
->setCellValue('D'.$row,$all);
$objPHPExcel->getActiveSheet()->getStyle('A'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('B'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('C'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('D'.$row_count)->applyFromArray($linestyle);
$baseRow++;
$row_count++;
}
$objPHPExcel->getActiveSheet()->getStyle('A'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('B'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('C'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('D'.$row_count)->applyFromArray($linestyle);
$objPHPExcel->getActiveSheet()->getStyle('A5:D'.$row_count)->applyFromArray($CENTER);
$objPHPExcel->getActiveSheet()->getStyle('A1:D'.$row_count)->applyFromArray($lineBORDER);
//设置打印页边距
$objPHPExcel->getActiveSheet()->getPageMargins()->setTop(0);
$objPHPExcel->getActiveSheet()->getPageMargins()->setRight(0);
$objPHPExcel->getActiveSheet()->getPageMargins()->setLeft(0);
$objPHPExcel->getActiveSheet()->getPageMargins()->setBottom(0);
//设置纸张类型
$objPHPExcel->getActiveSheet()->getPageSetup()->setPaperSize(PHPExcel_Worksheet_PageSetup::PAPERSIZE_A4);
//设置自动筛选
$objPHPExcel->getActiveSheet()->setAutoFilter('A5:D'.$row_count);
//设置自动换行
$objPHPExcel->getActiveSheet()->getStyle('B6:B'.$row_count)->getAlignment()->setWrapText(true);
//设置格式化数字
$objPHPExcel->getActiveSheet()->getStyle('A6:A'.$row_count)->getNumberFormat()->setFormatCode('0000000000');
//设置安全级别
$md=md5(time());
$md=substr($md,0,8);
$objPHPExcel->getActiveSheet()->getProtection()->setPassword("$md");
$objPHPExcel->getActiveSheet()->getProtection()->setSheet(true);//
$objPHPExcel->getActiveSheet()->getProtection()->setSort(true);
$objPHPExcel->getActiveSheet()->getProtection()->setInsertRows(true);
$objPHPExcel->getActiveSheet()->getProtection()->setFormatCells(true);
//添加图片
/*
$obj=$objPHPExcel->getActiveSheet();
$objDrawing=newPHPExcel_Worksheet_Drawing();
$objDrawing->setName('wsyImg');
$objDrawing->setDescription('Imageinsertedbyzhy');
$objDrawing->setPath('./wsy.jpg');
$objDrawing->setHeight(50);
$objDrawing->setCoordinates('H23');
$objDrawing->setOffsetX(60);
$objDrawing->setRotation(-10);/
$objDrawing->getShadow()->setVisible(true);
$objDrawing->getShadow()->setDirection(-20);/
$objDrawing->setWorksheet($obj);
*/
//页眉页脚
//$objPHPExcel->getActiveSheet()->getHeaderFooter()->setOddHeader('zhy');
//$objPHPExcel->getActiveSheet()->getHeaderFooter()->setOddFooter('end');
$objPHPExcel->setActiveSheetIndex(0);
$tname=date('Y-m-dH',time());
$tnam=iconv('UTF-8','GBK','祖名订单');
$tname=$tnam.$tname;
//Excel2007保存
//$objWriter=newPHPExcel_Writer_Excel2007($objPHPExcel);
//$objWriter->save(str_replace('.php','.xlsx',__FILE__));
//Excel5保存
//$objWriter=newPHPExcel_Writer_Excel5($objPHPExcel);
//$objWriter->save(str_replace('.php','.xls',__FILE__));
$objWriter=PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel5');
$objWriter->save(str_replace('.php','.xls',__FILE__));
//$url="/data/home/htdocs/ec/public/files/".date("Y")."/".date("Ym")."/";
createDir($url);
functioncreateDir($dir){
if(!is_dir($dir)){
mkdir($dir,0777,true);
chmod($dir,0777);
chown($dir,'daemon');
chgrp($dir,'daemon');
}
}
$name='forexmple_excel';
rename(str_replace('.php','.xls',__FILE__),$name.'.xls');
?>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!