一、动态生成的内容如何能当成文件来下载呢?

方法:1.将Content-Type设置成application/octet-stream就可以了,即【header('Content-Type: application/octet-stream'); 】

   2.用Content-Disposition设置下载的文件名,即【header('Content-Disposition: attachment; filename=' . $filename);】

a.基本上的下载程序都是这么写的:

 <?php
$filename = "document.txt";
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=' . $filename);
print "Hello!";
?>

b.平时我们也要考虑到浏览器的兼容性和中文文件名乱码的问题:

 <?php
//获取user agent
$ua = $_SERVER["HTTP_USER_AGENT"];
$filename = "文件名.txt";
$encoded_filename = urlencode($filename);
$encoded_filename = str_replace("+", "%20", $encoded_filename); header('Content-Type: application/octet-stream'); //判断是否为IE浏览器(IE10以下可以用MSIE判断,以上不行)
if (preg_match("/MSIE/", $ua)) {
header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');
} else if (preg_match("/Firefox/", $ua)) {
header('Content-Disposition: attachment; filename*="utf8\'\'' . $filename . '"');
} else { //其他
header('Content-Disposition: attachment; filename="' . $filename . '"');
} print 'ABC';
?>

二、原始一点的方法:发送header,用附件的表头发送到用户浏览器表示是要下载的,然后读出数据库中的数据,一条一条的解析,写入excel格式的文件中

 <?php
/**
*\n软换行
*\r软空格
*\t挑格(跳到下一列)
*/
// 连接数据库
$db = @mysql_connect('localhost','root','root'); if(!$db){
die('Could not connect: ' . mysql_error());
} //设置字符集
mysql_query("set names utf8");
//打开数据库
mysql_select_db("database"); $sql = "SELECT * FROM table_name LIMIT 100";
$result = mysql_query($sql); header('Content-Type: application/octet-stream');//下载
header("Content-Disposition: attachment; filename=sql.xls");//文件
header("Pragma: no-cache"); //不缓存 $title = '数据库:vvt,数据表:vvt_user,备份日期:'.date('Y/m/d/H/i/s');
//输出标题并换行(一个'\n'代表一行)
echo $title."\n"; //mysql_num_fields返回结果集中字段的数量
$columns_num = mysql_num_fields($result); //mysql_field_name返回结果集中的字段名,
for($i=0;$i<$columns_num;$i++){
//输出字段名称(表头)
echo mysql_field_name($result,$i). "\t";
} //将字段输出到一行后,下面就是拼接显示每一行字段对应的value
print("\n"); //添加内容(\t是跳列,跳到下一列)
$tab = "\t";
//mysql_num_rows返回结果集行数
if($result && mysql_num_rows($result)){
//得到关联数组mysql_fetch_assoc,mysql_fetch_row得到索引数组先循环数据
while($rows = mysql_fetch_row($result)){
// var_dump($rows);die;
$table_data = "";
//循环字段数,将每条数据对应的字段值填入对应的地方
for($j=0;$j<$columns_num;$j++){
if(!isset($rows[$j])){
//没值就使用'NULL'占位,并拼接"\t"跳到下一格
$table_data .= 'NULL'.$tab;
}elseif($rows[$j]){
$table_data .= "{$rows[$j]}".$tab;
}else{
$table_data .= "".$tab;
}
} $table_data = str_replace($tab.'$',"",$table_data);
// $table_data .= "\t";
print(trim($table_data));
print("\n");
$i++;
}
} //关闭mysql连接
mysql_close($con);
?>

三、PHPExcel库

  可以到官网去下载:http://phpexcel.codeplex.com/,解压后里面有三个目录

  Classes:此文件夹中是PHPExcel核心类库文件,我们对excel报表的处理都是通过此文件夹中的类文件来完成的,注意:所有的类名都是以PHPExcel_*开头的

  Documentation:这个文件夹中存放的是PHPExcel类库的英文说明文档

  Examples:是一些小的测试案例,这些小案例对于我们入门是非常有帮助的

  拓展:当输出数字字符串到excel文件中时,可在数字字符串前面拼接一个空格即可(或者指定单元格的数据类型为文本类型)

 <?php
//引入PHPExcel文件和Excel2007文件(用于输出.xls的)、Excel5(用于低版本的xls)
require_once './PHPExcel/Classes/PHPExcel.php';
require_once './PHPExcel/Classes/PHPExcel/Writer/Excel2007.php';
require_once './PHPExcel/Classes/PHPExcel/Writer/Excel5.php'; //实例化PHPExcel对象
$objExcel = new PHPExcel();
$objWriter = new PHPExcel_Writer_Excel2007($objExcel);
// $objWriter = new PHPExcel_Writer_Excel5($objExcel);非2007格式 //设置一个活动表(第一个工作表为活动表)
$objExcel->setActiveSheetIndex(0);
/*********************************************部分功能说明 start*********************************************/
//设置单元格内容setCellValue(设置单元格的值)、setCellValueExplicit(设置单元格的值,并显示的指定数据的类型)
$objExcel->getActiveSheet()->setCellValueExplicit('A1','名字',PHPExcel_Cell_DataType::TYPE_STRING);
17 $objExcel->getActiveSheet()->setCellValue('A1','名字'); //文字水平居中setHorizontal
$objExcel->getActiveSheet()->getStyle('A1')->getAlignment()->setHorizontal($option);
//文字垂直居中setVertical
$objExcel->getActiveSheet()->getStyle('A1')->getAlignment()->setVertical($option);
// 合并
$objExcel->getActiveSheet()->mergeCells('A1:B1');
// 拆分
$objExcel->getActiveSheet()->unmergeCells('A1:B1');
//设置单元格列setWidth(宽度)、setAutoSize(列的宽度刚好为字体内容的宽度)
$objExcel->getActiveSheet()->getColumnDimension('A')->setWidth('10')->setAutoSize(true);
//设置字体setName(字体)、setSize(大小)、setBold(粗体)、setUnderline(设置下划线)、setItalic(字体倾斜)
$objExcel->getActiveSheet()->getStyle('A1')->getFont()->setName('黑体')->setSize(20)
->setBold(true)->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE)->setItalic();
//设置字体颜色
$objExcel->getActiveSheet()->getStyle('A1')->getFont()->getColor()
->setARGB(PHPExcel_Style_Color::COLOR_BLUE);
//设置单元格边框样式(getTop、getLeft、getRight、getBottom)
$objExcel->getActiveSheet()->getStyle('B4')->getBorders()->getLeft()
->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
//设置单元格边背景
$objExcel->getActiveSheet()->getStyle('B5')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
//设置工作表保护(导出的表格为只读,不能编辑)
$objExcel->getActiveSheet()->getProtection()->setSheet(true); /*********************************************部分功能说明 end*********************************************/
//输出到浏览器(文件名为中文时要转码使用iconv或mb_convert_encoding)
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header('Content-Disposition:inline;filename="'.$filename.'.xls"');
header("Content-Transfer-Encoding: binary");
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Pragma: no-cache");
$objWriter->save('php://output');exit; ?>

下面是部分参数:

  setUnderline的部分参数:
    PHPExcel_Style_Font::UNDERLINE_NONE
    PHPExcel_Style_Font::UNDERLINE_DOUBLE(双下划线)
    PHPExcel_Style_Font::UNDERLINE_DOUBLEACCOUNTING(双下划线)
    PHPExcel_Style_Font::UNDERLINE_SINGLE(下划线)
    PHPExcel_Style_Font::UNDERLINE_SINGLEACCOUNTING(下划线)

  setVertical参数:
    PHPExcel_Style_Alignment::VERTICAL_TOP(顶部)
    PHPExcel_Style_Alignment::VERTICAL_CENTER(垂直居中)
    PHPExcel_Style_Alignment::VERTICAL_BOTTOM(底部)
    PHPExcel_Style_Alignment::VERTICAL_JUSTIFY 

  setHorizontal参数:
    PHPExcel_Style_Alignment::HORIZONTAL_GENERAL
    PHPExcel_Style_Alignment::HORIZONTAL_LE
    PHPExcel_Style_Alignment::HORIZONTAL_CENTER(水平居中)
    PHPExcel_Style_Alignment::HORIZONTAL_RIGHT(右对齐)
    PHPExcel_Style_Alignment::HORIZONTAL_FILL
    PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY
    PHPExcel_Style_Alignment::HORIZONTAL_CENTER_CONTINUOUS

四、使用PHPExcel库对于大数据的支持度不是很好,很容易达到php内存上限,这里利用fputcsv写CSV(这是一种逗号分割值文件格式)

  

 <?php
// 输出Excel文件头,可把excel.csv换成你要的文件名
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="excel.csv"');
header('Cache-Control: max-age=0'); $db = @mysql_connect('localhost','root','root'); if(!$db){
die('Could not connect: ' . mysql_error());
} //设置字符集
mysql_query("set names utf8");
//打开数据库
mysql_select_db("database"); $sql = "SELECT id,'活动名称',user_id,u_name,reward,CASE r_level WHEN 1 THEN '中奖' WHEN 0 THEN '未中奖' END,CASE type WHEN 1 THEN '奖励1' WHEN '2' THEN '奖励2' WHEN 3 THEN '奖励3' END,add_time FROM tablename";
$result = mysql_query($sql); $head = array('id','活动名称','用户id','用户名','中奖额度','是否中奖','中奖类型','抽奖时间'); //打开php文件句柄,php://output表示直接输出到浏览器,a表示写入方式打开
$fp = fopen('php://output', 'a'); foreach($head as $key=>$val){
$head[$key] = mb_convert_encoding($val,'GBK','UTF-8');
} //将数据通过fputcsv写到文件句柄
fputcsv($fp,$head); //计数
$total = 0; //每隔1000行刷新一下缓存buffer,不要太大,也不要太小
$limit = 1000; if($result && mysql_num_rows($result)){
while($rows = mysql_fetch_row($result)){
$total++;
if($total == $limit){
//送出缓冲区的内容
ob_flush();
//刷新php程序的缓存
flush(); $total = 0;
} foreach($rows as $k=>$v){
$rows[$k] = mb_convert_encoding($v,'GBK','UTF-8');
} fputcsv($fp,$rows); }
62     die();
} ?>

php:PHPExcel导出excel表格的更多相关文章

  1. PHPExcel导出excel表格

    if(!function_exists('exportExcel')){    //导出excel文件    function exportExcel($datas, $save_method='ht ...

  2. PHPEXCEL导出excel表格中长数字文本自动转为科学计数法的解决办法

    方法一:前面加空格 $objActSheet->setCellValue('A1', ' '.'330602198804224688'); 方法二: $objActSheet->setCe ...

  3. tp5.0 composer下载phpexcel 实现导出excel 表格

    tp5.0 composer下载phpexcel 实现导出excel 表格 1.在下载好的tp5.0 框架里面使用 composer 下载phpexcel 的插件 composer require p ...

  4. PHP导入导出excel表格图片(转)

    写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xml的也用过,csv的就更不用谈了.呵呵.(COM方式不讲了,这种可读的太多了,我也写过利用wp ...

  5. php header函数导出excel表格

    推荐一个除了用PHPExcel导出表格之外的另外一种比较简单不需要引入类文件的表格导入方法——header()导出excel表格. 导出表格的步骤封装成了方法,以便于重复使用,代码如下: /** * ...

  6. PHP导入导出excel表格图片的代码和方法大全

    基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件 ...

  7. java中使用jxl导出Excel表格详细通用步骤

    该方法一般接收两个参数,response和要导出的表格内容的list. 一般我们将数据库的数据查询出来在页面进行展示,根据用户需求,可能需要对页面数据进行导出. 此时只要将展示之前查询所得的数据放入s ...

  8. .NET环境下导出Excel表格的两种方式和导入两种类型的Excel表格

    一.导出Excel表格的两种方式,其中两种方式指的是导出XML数据类型的Excel(即保存的时候可以只需要修改扩展名为.xls)和真正的Excel这两种. using System; using Sy ...

  9. java导出excel表格

    java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...

随机推荐

  1. smarty3.0中文手册文档API及使用指南

    1.安装Smarty3.0一.什么是smarty?smarty是一个使用PHP写出来的模板PHP模板引擎,它提供了逻辑与外在内容的分离,简单的讲,目的就是要使用PHP程序员同美工分离,使用的程序员改变 ...

  2. hiho42 : 骨牌覆盖问题·二

    描述 上一周我们研究了2xN的骨牌问题,这一周我们不妨加大一下难度,研究一下3xN的骨牌问题?所以我们的题目是:对于3xN的棋盘,使用1x2的骨牌去覆盖一共有多少种不同的覆盖方法呢?首先我们可以肯定, ...

  3. Peeking into Apache Flink's Engine Room

    http://flink.apache.org/news/2015/03/13/peeking-into-Apache-Flinks-Engine-Room.html   Join Processin ...

  4. ArcGIS Server 缓存服务切图范围

    win10 + Server 10.4 +  ArcMap 10.4  ArcGIS Server 缓存服务分为创建服务后手动建立缓存和创建服务时同时自动建立缓存两种. 10.2帮助文档:http:/ ...

  5. Delphi下使用MapWinGIS控件打开GIS图层

    unit Unit3; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System ...

  6. OpenMP for Fortran

    OpenMP for Fortran OpenMP Directive Syntax of OpenMP compiler directive for Fortran: !$OMP Directive ...

  7. 区分总结innerHeight与clientHeight、innerWidth与clientWidth、scrollLeft与pageXOffset等属性

    window对象: (1)innerHeight属性:窗口中文档显示区域的高度,不包括菜单栏.工具栏等部分.该属性可读可写. IE不支持该属性,IE中body元素的clientHeight属性与该属性 ...

  8. java并发编程-线程池的使用

    参考文章:http://www.cnblogs.com/dolphin0520/p/3932921.html 深入剖析线程池实现原理 将从下面几个方面讲解: 1.线程池状态 2.任务的执行 3.线程池 ...

  9. 【C】用我所学去讲C语言指针

    很多人不敢讲C的指针,有些人讲不清,有些人怕讲错.初生牛犊不怕虎,就让我讲讲. 下面开始. 一.指针的定义  指针是内存单元的编号.内存单元是以字节为单位的.所以指针就是字节的编号. 比如我们的个人电 ...

  10. style="display"之后不能获取offsetHeight或clientWidth这类测量的值

    如果在html元素中设置了style="display:none;height:90px;"的属性后,是无法获得offsetLeft ,offsetWidth,offsetTop, ...