利用phpexcel对数据库数据的导入excel(excel筛选)、导出excel

<?php
/*
*author zhy
*date 2012 06 12
*for excel
*/
date_default_timezone_set("PRC"); 
error_reporting(E_ALL);
error_reporting(0);
ini_set(‘display_errors‘, TRUE);
ini_set(‘display_startup_errors‘, TRUE);
define(‘EOL‘,(PHP_SAPI == ‘cli‘) ? PHP_EOL : ‘<br />‘);
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 = new PHPExcel();
////////获取文档信息
////////$objProps = $objPHPExcel->getProperties();
///////print_r($objProps);
///////echo "<br/>";
///////$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‘,"select i.goods_id , sum( `nums` ) AS num, i.name,i.addon,i.price,g.bn as b,i.bn as h,
g.goods_id,i.goods_id,i.order_id
FROM `sdb_b2c_order_items` as i,sdb_b2c_goods as g
WHERE i.order_id in (select order_id from sdb_b2c_orders where status =‘active‘ and createtime between $stime and $etime) and i.goods_id=g.goods_id and g.cat_id=173 GROUP BY h");
$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($re as $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 = new PHPExcel_Worksheet_Drawing();   
$objDrawing->setName(‘wsyImg‘);   
$objDrawing->setDescription(‘Image inserted by zhy‘);   
$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;
// Excel 2007保存
//$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel); 
//$objWriter->save(str_replace(‘.php‘, ‘.xlsx‘, __FILE__)); 
  
// Excel 5保存 
//$objWriter = new PHPExcel_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);
function createDir($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‘);
?>

http://www.cnblogs.com/yuwensong/p/3771787.html
时间: 2024-10-13 08:57:02

利用phpexcel对数据库数据的导入excel(excel筛选)、导出excel的相关文章

java 操作 Excel,java导出excel

WritableWorkbook out = null; try { response.getServletResponse().reset(); ((HttpServletResponse) response.getServletResponse()).setHeader("Content-Disposition", "attachment;filename=export.xls"); response.getServletResponse().setConten

.Net常用技巧_调用Excel模板格式导出Excel

object missing = System.Reflection.Missing.Value;  //表示缺i省object SaveFileDialog savedialog = new SaveFileDialog(); savedialog.Filter = "(*.xlsx)|*.xlsx|(*.xls)|*.xls"; savedialog.Title = "导成Excel"; if (savedialog.ShowDialog() == Dialog

DataTable 更改在有数据列的类型方法+DataTable 导出excel功能

/// <summary> /// 导出功能 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void btn_export_Click(object sender, EventArgs e) { try { string strSql = CreateStrWhere

用excel.php类库导出excel文件

excel.php是个小型的php类库,可以满足基本的从数据库中取出数据然后导出xls格式的excel文件,代码如下: 1 class Excel { 2 public $filename = 'excel'; 3 public $custom_titles; 4 5 public function make_from_db($db_results) 6 { 7 $data = NULL; 8 $fields = $db_results->field_data(); 9 if ($db_resu

C# NPOI导出Excel和EPPlus导出Excel比较

系统中经常会使用导出Excel的功能. 之前使用的是NPOI,但是导出数据行数多就报内存溢出. 最近看到EPPlus可以用来导出Excel,就自己测了下两者导出上的差异. NPIO官网地址:http://npoi.codeplex.com/ EPPlus官网地址:http://epplus.codeplex.com/ 添加NPOI.EPPlus类库dll使用的是NuGet添加. 在类库References右键Manage NuGet Packages...,之后选择添加对应的dll. 测试结果显

PHPEXCEL生成excel文件与导出excel文件

<?php Header("Content-type:text/html;charset=utf-8"); error_reporting(E_ALL & ~E_NOTICE); require_once(ESF_DIR.'/zjadmin/phpexcel/Classes/PHPExcel.php'); $db->query("set names utf8"); $Info_area=array(2=>"x山区",1=

【Spring+Excel】spring导出Excel

需要的jar包 以poi开头的jar包都是必须的 web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:s

php利用PHPExcel类导出导入Excel用法

PHPExcel类是php一个excel表格处理插件了,下面我来给大家介绍利用PHPExcel类来导入与导出excel表格的应用方法,有需要了解的朋友不防参考参考(PHPExcel自己百度下载这里不介绍了). 导出Excel用法 //设置环境变量(新增PHPExcel) 1 set_include_path('.'. PATH_SEPARATOR . Yii::app()->basePath.'/lib/PHPExcel' . PATH_SEPARATOR . 2 3 get_include_p

Java将数据库数据导入EXCEL

一般的数据库数据怎么导入excel中呢??这让人非常疑惑,今天我找到了一个方法能够实现 须要导入一个第三方包下载地址 详细内容例如以下: 里面含有指导文档,index.html里面含有怎样读取数据库文件到excel和excel数据到数据库中. 主要用到一个包 将这个包复制到项目里面就能够了. 先做一个简单版本号的helloword <span style="white-space:pre"> </span>public void mkexcel() throws