- 浏览: 228530 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
yjw0628:
text 和password无需分开处理.然后不要用input ...
jquery html5 实现placeholder 兼容password ie6 -
supercrsky:
不输入直接提交form会有各种问题。
jquery html5 实现placeholder 兼容password ie6 -
myfreespace:
嗯 谢谢提示,正在修改中
模仿新浪微薄 删除冒泡提示效果 -
王斌_code:
有bug,先点删除,再点取消,在冒泡消失前,点击删除(构造事件 ...
模仿新浪微薄 删除冒泡提示效果 -
王斌_code:
效果有点生硬,用jquery可以省不少事,而且效果很好
模仿新浪微薄 删除冒泡提示效果
/* * 导出excel表格 * 根据统计标题信息、日期信息和excel表格标示信息 * 先循环统计标题信息在循环每条统计下面按日期的具体信息 * 进行单元格设置 合并 添加样式 */ function _export($tipMsg = null, $date = null, $excelTitle = null){ $this->autoRender = false; App::import('Vendor', 'phpexcel', array('file' => 'PHPExcel.php')); App::import('Vendor', 'phpexcelwriter', array('file' => 'PHPExcel'.DS.'Writer'.DS.'Excel2007.php')); // loads PHPExcel/Writer/Excel2007.php $objPHPExcel = new PHPExcel(); $excelName = 'speiyou_'.date('y-m-d H:i:s').'.xls';//文件名字 // 设置属性 $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"); //样式声明 $objActSheet = $objPHPExcel->getActiveSheet(); //设置样式字体 $sharedStyle1 = new PHPExcel_Style(); $sharedStyle1->applyFromArray( array('fill' => array('type' => PHPExcel_Style_Fill::FILL_SOLID,'color' => array('argb' => 'FFCCFFCC')), 'borders' => array('bottom'=> array('style' => PHPExcel_Style_Border::BORDER_THIN), 'right'=> array('style' => PHPExcel_Style_Border::BORDER_THIN), 'top' => array('style' => PHPExcel_Style_Border::BORDER_THIN), 'left' => array('style' => PHPExcel_Style_Border::BORDER_THIN)), 'font' => array('bold' => true,'color'=>array('argb' => '00000000')), )); // 添加头部数据 $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A1', '模块分类') ->setCellValue('B1', '点击代码') ->setCellValue('C1', '代码名称'); foreach ($date as $tdk => $tdv) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$tdk].'1', $date[$tdk]); } /*添加主要内容 * 分类处理 tou(头部导航) banji(班级分类) fonepage(首页一屏) ftwopage(首页二屏) fthreepage(首页三屏) * bottom(底部) teacher(名师) ad(广告) */ $num = 2;//循环开始标记位 $datenum = count($date) - 1; foreach($tipMsg as $k => $v) { if ($k == 'tou') { $tounum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A2','头部导航'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objActSheet->mergeCells('A2'.':A'.$newnum); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A2:A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].'2:'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'banji') { $banjinum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$tounum,'班级分类'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$tounum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$tounum.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'fonepage') { $fonepagenum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$banjinum,'首页一屏'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$banjinum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$banjinum.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'ftwopage') { $ftwopagenum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$fonepagenum,'首页二屏'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$fonepagenum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$fonepagenum.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'fthreepage') { $fthreepage = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$ftwopagenum,'首页三屏'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$ftwopagenum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$ftwopagenum.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'bottom') { $bottomnum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$fthreepage,'底部'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$fthreepage.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$fthreepage.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'teacher') { $teachernum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$bottomnum,'名师频道'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$bottomnum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$bottomnum.':'.$excelTitle[$datek].$newnum.')'); } } elseif ($k == 'ad') { $adnum = $num + 1; $newnum = $num-1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$teachernum,'通栏广告'); //合并单元格 $objActSheet->mergeCells('A'.$num.':C'.$num); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$teachernum.":A".$newnum); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '本类汇总'); $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A".$num.":".$excelTitle[count($date) - 1].$num); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //求和 foreach($date as $datek => $datev) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$datek].$num,'=SUM('.$excelTitle[$datek].$teachernum.':'.$excelTitle[$datek].$newnum.')'); } } else { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '') ->setCellValue('B'.$num, $v['codetip']) ->setCellValue('C'.$num, $v['codename']); foreach($date as $tdk => $tdv) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$tdk].$num, $v['nums'][$tdk]); } } ++$num; } //添加样式 $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A1:".$excelTitle[count($date) - 1]."1"); // $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, "A1:A".$num); //冻结列 $objPHPExcel->getActiveSheet()->freezePane('A1'); $objPHPExcel->getActiveSheet()->freezePane('B1'); $objPHPExcel->getActiveSheet()->freezePane('C1'); $objPHPExcel->getActiveSheet()->freezePane('D2'); //设置居中 $objActSheet->getStyle('A2')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //设置列宽 $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(20); //设置底部总数统计信息 $ttotal = $tounum - 1; $banjitotal = $banjinum - 1; $fototal = $fonepagenum - 1; $fttotal = $ftwopagenum - 1; $frtotal = $fthreepage - 1; $btotal = $bottomnum - 1; $chtotal = $teachernum - 1; $adtotal = $adnum - 1; $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A'.$num, '总计') ->setCellValue('B'.$num, '') ->setCellValue('C'.$num, '日统计'); foreach ($date as $totalk => $totalv) { $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($excelTitle[$totalk].$num, '=SUM('.$excelTitle[$totalk].$ttotal.','.$excelTitle[$totalk].$banjitotal.','.$excelTitle[$totalk].$fototal.','.$excelTitle[$totalk].$fttotal.','.$excelTitle[$totalk].$frtotal.','.$excelTitle[$totalk].$btotal.','.$excelTitle[$totalk].$chtotal.','.$excelTitle[$totalk].$adtotal.')'); } $objPHPExcel->getActiveSheet()->setSharedStyle($sharedStyle1, 'A'.$num.':'.$excelTitle[$datenum].$num); $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('B'.$num, '=SUM(D'.$num.':'.$excelTitle[$datenum].$num.')'); $objActSheet->getStyle('A'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); $objActSheet->getStyle('C'.$num)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); // 设置切换标签的名字 $objPHPExcel->getActiveSheet()->setTitle('培优网用户点击统计'); //直接输出到浏览器 header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="'.$excelName.'"'); header('Cache-Control: max-age=0'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); exit; }
发表评论
-
win7 php nginx配置
2012-05-14 17:13 0因为公司更换服务器,从apache到nginx,所以自己的环境 ... -
简单的sql注入及预防
2012-02-06 15:15 1046简单的sql注入是通过web页面中的输入框输入特殊的查询字符 ... -
php curl模块加载失败 解决办法
2011-08-17 14:35 3131cURL 是一个利用URL语法规定来传输文件和数据的工具,支持 ... -
cakephp find like用法
2011-06-30 19:32 1232$districts = $this->School-& ... -
php 截取中文字符
2011-06-23 17:13 1013<?php /* *截取字符串 *bilib ... -
textarea 回车 空格转换
2011-06-20 18:16 1205在处理文本框textarea的时候,str_replace(c ... -
php给编辑器中的图片添加域名
2011-06-12 00:43 3538/** * 替换fckedit中的图片 添加域名 ... -
phpmail发送邮件
2011-05-05 17:28 1313简单的发送邮件:用到wordpress里面的两个类,下载地址h ... -
base64_encode和serialize的实用和区别
2011-05-04 19:16 1115serialize()产生一个可存储的值的表示,返回字符串,此 ... -
zendstudio 常用快捷键
2011-04-21 12:56 1204在开发中用到的IDE为zendstudio,使用快捷键可以提高 ... -
php截取中文乱码问题
2011-03-24 18:32 1145在页面显示链接地址的时候,要控制字数,字母还没问题,当遇到中文 ... -
php中null empty isset判断空
2011-03-19 15:16 1624在平时的条件判断中true 和 false是常用的,判断常用的 ... -
cakephp bake生成
2011-03-18 18:11 1109bake生成是cakephp快速建站的工具 配置环境变量 ... -
cakephp 分页 session
2011-03-16 19:29 2043分页: 在cakephp中很多都是通过components来 ... -
cakephp session学习
2011-03-14 18:39 1402// Revert value and get rid ... -
cakephp cookies的学习
2011-03-14 17:21 3487cakephp的cookie是作为一个插件封装了php的coo ... -
cakephp访问控制
2011-03-14 16:55 13381.cakephp中的访问控制ACL 请求访问对象ARO 访 ... -
cakephp学习中的点滴
2011-03-14 00:45 9891 model层的操作 基类为dbo_mysql.php ca ... -
apache 服务器的一些配置
2011-03-12 03:03 12671,基于主机名的虚拟主机,基于域名的虚拟主机可以多个域名使用同 ... -
搭建php环境 虚拟目录的两种配置方法vhost rewrite
2011-03-10 18:00 1634模块加载 基本的配置要完整 .htaccess文件提供了针对 ...
相关推荐
它提供了丰富的API,允许开发者在Web应用中方便地生成Excel表格,处理数据导入和导出功能,尤其适用于需要大量处理表格数据的场景。下面将详细介绍PHPExcel的使用方法、功能以及与之相关的知识点。 一、安装和配置 ...
`phpExcel`是一个广泛使用的PHP库,用于读取和生成电子表格文件,特别是Microsoft Excel格式。这个库使得在服务器端用PHP处理Excel数据变得简单,适用于数据导出、报表生成等场景。以下是对`phpExcel`相关知识点的...
总的来说,PHPExcel为PHP开发者提供了一种强大的工具,用于生成和处理Excel文件,尤其在需要从Web应用程序导出大量数据时非常有用。这个库支持丰富的功能,如样式设置、公式计算、图表创建等,使得创建复杂的Excel...
本实例将深入探讨如何使用`PHPExcel`来生成Excel文件。 1. **安装PHPExcel** 在开始之前,你需要首先安装`PHPExcel`库。如果你使用Composer管理项目依赖,可以通过以下命令进行安装: ```bash composer require ...
总之,PHPExcel 1.8是PHP开发人员处理Excel文件的强大工具,尤其在需要进行批量数据导入导出或自动化报告生成的场景下。尽管它现在已经不再维护,但在许多现有的项目中仍被广泛使用。如果你的项目需要与Excel交互,...
本示例将介绍使用PHPExcel进行多工作表(sheet)的表格导出操作。 首先,要使用PHPExcel,需要下载其文档并解压。之后,需要在PHP脚本中引入PHPExcel类,代码如下: ```php set_include_path('.'.get_include_path...
本篇文章将深入探讨如何利用`phpExcel`库来处理带有图片的Excel表格。 首先,我们需要理解`phpExcel`的基本用法。安装`phpExcel`可以通过Composer,运行`composer require phpoffice/phpexcel`命令。然后,通过`...
在PHP开发中,生成Excel文件是一项常见的任务,尤其在数据导出、报表生成或数据分析等场景下。本篇文章将深入探讨如何使用PHP类库来创建并保存Excel文件到指定的目录,以满足这类需求。 首先,PHP有一个常用的库...
通过调用PHPExcel的`getActiveSheet()`方法获取当前工作表,然后使用`generateHTMLHeader()`和`generateHTMLFooter()`方法生成表格的头部和尾部,`generateHTMLRow()`方法则用于生成表格行。最后,这些HTML代码可以...
2. **样例**:可能提供了一些示例代码,展示了如何使用PHPExcel库来处理Excel文件,例如创建表格、设置单元格样式、公式计算等。通过学习这些样例,开发者可以快速掌握使用方法。 3. **CSS格式文件**:虽然Excel是...
通过使用PHPExcel,开发者可以在PHP环境中轻松地创建复杂的电子表格,进行数据导入导出,甚至实现报表自动化。 二、主要功能 1. **读取Excel文件**:可以从.xls和.xlsx文件中提取数据,支持多工作表和公式解析。 2....
1. 文件读取:PHPExcel支持读取多种格式的电子表格文件,包括.XLS、.XLSX、.CSV、.ODS等。 2. 文件写入:可以创建新的Excel文件或更新现有文件,支持.BIFF8(Excel 97-2003)和开放式XML(Excel 2007及以上)格式。 ...
这个库允许开发者在服务器端创建、读取、编辑和展示Excel文件,广泛应用于数据导入导出、报表生成以及数据分析等场景。 1. **PHPExcel的基本概念** - **PHPExcel类库**:它是由Mark Baker开发的,提供了一组丰富的...
下面将详细介绍如何在ThinkPHP 3.2中利用PHPExcel实现表格导出功能: 1. **安装PHPExcel**:首先,你需要在项目中引入PHPExcel库。可以通过Composer进行安装,或者直接下载源代码并将其放在项目的 Vendor 目录下。 ...
PHPExcel 常用于数据分析、报表生成、数据导入导出等场景。例如,网站后台可以使用它来批量处理用户上传的 Excel 数据,或者生成报表供用户下载。此外,还可以用于自动化数据处理流程,将数据库数据导出为 Excel ...
PHPExcel是一个广泛使用的PHP库,专为处理电子表格文件如Microsoft Excel而设计。它允许开发者在服务器端生成、读取、编辑Excel文件,无需依赖Microsoft Office软件。这个强大的库支持多种文件格式,包括.xls (BIFF8...
PHPExcel是一款广泛使用的开源库,专门用于在PHP环境中读取、写入和操作Microsoft Excel(XLS、XLSX)以及PDF格式的电子表格文件。它通过一系列的API接口,使得开发者可以方便地处理各种Excel相关的任务,如数据导入...
当我们需要在PHP应用程序中生成或操作Excel表格时,可以借助一些库来实现,其中PHPExcel是一个常用的选择。 标题"php生成excel表格"指的是利用PHP编程语言来创建和处理Excel文件的过程。这通常涉及到以下几个关键...
1. **Reader和Writer**:分别用于读取和写入电子表格文件,每种文件格式都有对应的实现类,如`PHPExcel_Reader_Excel5`用于读取.BIFF8格式,`PHPExcel_Writer_Excel2007`用于写入.OpenXML格式。 2. **Worksheet和...