标签分类
技术文章
当前位置:主页 > 计算机编程 > php > PHP中excel的导出和下载(实例讲解)

PHP中excel的导出和下载实例代码

  • 发布时间:
  • 作者:码农之家原创
  • 点击:165

PHP中excel的导出和下载(实例讲解)

这篇文章主要知识点是关于excel导出下载,PHP中excel的导出和下载(实例讲解),php原生导出excel文件的两种方法(推荐) 的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

PHP、MySQL与JavaScript学习手册
  • 类型:PHP大小:76 MB格式:PDF出版:中国电力出版社作者:Robin Nixon
立即下载

更多相关的学习资源可以参阅 程序设计电子书PHP电子书、等栏目。

1、前言

有时需要将数据库表资源导出excel,做成一些报表数据。

而php导出excel的方法大致有几种:

1. 使用php的类库,进行导出,如PHPExcel

2.使用php原生的方法进行导出

而本文介绍的就是,如何通过原生方法导出excel

2、关键函数

2.1、ob输出

•ob_start();
•ob_get_contents
•ob_end_clean
•fopen
•fwrite
•fclose
•iconv

2.2、header输出

1.header
2.iconv

3、使用ob函数进行excel到导出

ob函数主要分为三步:

1.进行缓存的设置
2.读取缓存
3.写入文件

下面贴上导出的excel类

<?php
class Excel 
{
 // ob函数缓存的开始
 public static function start ()
 {
  ob_start();
 }
 // 获取缓存内容
 public static function save ($path) 
 {
  $data = ob_get_contents();
  ob_end_clean();
  self::writeToExcel($path, $data);
 }
 //写到文件
 private static function writeToExcel ($fn, $data) 
 {
  $dir = self::setDir();
  $fp = fopen($dir . '/'. $fn, 'wb');
  fwrite($fp, $data);
  fclose($fp);
 }
 //excel默认是GKB,所有要转码
 public static function setChar ($value, $inchar = 'utf-8', $outchar ='gbk')
 {
  return iconv($inchar, $outchar, $value);//转化编码
 }
 //创建目录,linux系统一般要写到文件,目录需要w谦虚,而文件需要x权限,为了省事直接建立子文件夹,可以不需要修改谦虚
 public static function setDir($dirName = 'excel')
 {
  if(!is_dir($dirName)) {
   mkdir($dirName);
  }
  return $dirName;
 }
}

4、完整页面代码

<?php
 header('Content-Type: text/html; charset=GBK'); //excel需要GBK编码,为了防止转码产生的乱码,需要设置成GBK
 require 'coon.php';
 require 'excel.class.php';

 $sql = 'select * from user';
 $res = $link->query($sql);
 //判断是否有发送get数据
 if(isset($_GET['id'])){
  $name = empty($_GET['id']) ? 'a' . rand(1000,9999) : $_GET['id'] ;
  $filename = $name . '.xls';
  //设置缓存的开始
  Excel::start();
 }
?>
<?php
 //页面输出一般是不需要转码的,excel输出才需要转码
 echo '<table width=500 height=25 border=0 align=center cellpadding=0 cellspacing=0>';
 echo '<thead><tr>';
 //设置thead输出
 echo '<td >' . Excel::setChar('编号') . '</td>';
 echo '<td >' . Excel::setChar('用户名') . '</td>';
 echo '<td >' . Excel::setChar('密码') . '</td>';
 echo '</thead></tr>';
?>
<?php
 echo '<tbody>';
 //设置tbody输出
 while($re = $res->fetch(PDO::FETCH_ASSOC)){
  echo '<tr>';
  echo '<td >' . Excel::setChar($re['id']) . '</td>';
  echo '<td >' . Excel::setChar($re['user']) . '</td>';
  echo '<td >' . Excel::setChar($re['pwd']) . '</td>';
  echo '</tr>';
 }
 echo '</tbody></table>';
?>
<?php
if(isset($_GET['id'])){
 //保存文件
 Excel::save($filename);
}
if(isset($_GET['id'])){
 echo '<a href="obexcel.php" rel="external nofollow" >' .Excel::setChar('完成') .'</a>';
}else{
 echo '<a href="obexcel.php?id" rel="external nofollow" >' . Excel::setChar('导出') .'</a>';
 
}
?>

5、使用header下载excel

使用ob函数导出excel只能保存到服务器,不能提供下载(特殊处理下还是可以的);下面介绍使用header()函数来导出并下载excel

主要两个header()函数

header("Content-type:application/vnd.ms-excel");//指定文件类型 
header("Content-Disposition:filename=a.xls" ); //指定下载文件名

其他做法和ob函数的导出相同(下面完整代码)

<?php

//下载主要靠这两个
header("Content-type:application/vnd.ms-excel");//指定文件类型 
header("Content-Disposition:filename=a.xls" ); //指定下载文件名
require 'coon.php';
require 'excel.class.php';
$sql = 'select * from user';
$res = $link->query($sql);
?>

<?php
 //页面输出一般是不需要转码的,excel输出才需要转码
 echo '<table width=500 height=25 border=0 align=center cellpadding=0 cellspacing=0>';
 echo '<thead><tr>';
 //设置thead输出
 echo '<td >' . Excel::setChar('编号') . '</td>';
 echo '<td >' . Excel::setChar('用户名') . '</td>';
 echo '<td >' . Excel::setChar('密码') . '</td>';
 echo '</thead></tr>';
?>

<?php
 echo '<tbody>';
 //设置tbody输出
 while($re = $res->fetch(PDO::FETCH_ASSOC)){
  echo '<tr>';
  echo '<td >' . Excel::setChar($re['id']) . '</td>';
  echo '<td >' . Excel::setChar($re['user']) . '</td>';
  echo '<td >' . Excel::setChar($re['pwd']) . '</td>';
  echo '</tr>';
 }
 echo '</tbody></table>';
?>

6、结语

这里只简单介绍了excel的导出和下载,一个是使用ob()函数,一个是使用header()函数,两种方法大同小异,但都需要注意的是excel需要GBK编码,需要使用iconv函数进行转码,才能保证不出现乱码。

本文只简单了介绍,更多高深的方法需要由你自己去探索。

以上这篇excel的导出和下载(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。

php原生导出excel文件的两种方法(推荐)

第一种方法:

$filename='文件名称';
  $filetitle='你的标题';
  if($_POST){
    set_time_limit(10000);
    $title = '';
    ini_set('memory_limit','300M');
    header('Content-Type: application/vnd.ms-excel;charset=utf-8');
    $name = $title.".xls";
    header('Content-Disposition: attachment;filename='.$name.'');
    header('Cache-Control: max-age=0');
    $where = "1=1";
    $sql = "";
    $query = DB::Query($sql);
    // PHP文件句柄,php://output 表示直接输出到浏览器 
    $fp = fopen('php://output', 'a');
    // 输出Excel列头信息 
    $head = array('ID');
    //字符替换
    $p_new_lines = array("\r\n", "\n","\t","\r","\r\n", "<pre>","</pre>","<br>","</br>","<br/>");
    $p_change_line_in_excel_cell = '';

    foreach($head as $v){
      echo iconv('utf-8','gb2312',$v) . "\t";
    }
    echo "\n";
    // 计数器 
    $cnt = 0;
    // 每隔$limit行,刷新一下输出buffer,节约资源 
    $limit = 100000;
    // 逐行取出数据,节约内存
    while ($res = mysql_fetch_assoc($query)) {
      $cnt ++;
      if ($limit == $cnt) { //刷新一下输出buffer,防止由于数据过多造成问题 
        ob_flush();
        flush();
        $cnt = 0;
      } 
      echo trim($res['id']). "\t";
      echo "\n";
    }

  }

第二种方法:

$filename='文件名称';
  $filetitle='你的标题';
  if($_POST){
    $title = '';
    ini_set('memory_limit','300M');
    header('Content-Type: application/vnd.ms-excel;charset=utf-8');
    $name = $title.".xls";
    header('Content-Disposition: attachment;filename='.$name.'');
    header('Cache-Control: max-age=0');
    echo '<html xmlns:o="urn:schemas-microsoft-com:office:office"
      xmlns:x="urn:schemas-microsoft-com:office:excel"
      xmlns="http://www.w3.org/TR/REC-html40">
    <head>
      <meta http-equiv="expires" content="Mon, 06 Jan 1999 00:00:01 GMT">
      <meta http-equiv=Content-Type content="text/html; charset=gb2312">
      <!--[if gte mso 9]><xml>
      <x:ExcelWorkbook>
      <x:ExcelWorksheets>
       <x:ExcelWorksheet>
       <x:Name></x:Name>
       <x:WorksheetOptions>
        <x:DisplayGridlines/>
       </x:WorksheetOptions>
       </x:ExcelWorksheet>
      </x:ExcelWorksheets>
      </x:ExcelWorkbook>
      </xml><![endif]-->
    </head>';
    $where = "1=1";

    $sql = " ";
    mysql_query('set names "utf8"');
    mysql_set_charset('utf8');
    $query = DB::Query($sql);

    // PHP文件句柄,php://output 表示直接输出到浏览器 
    $fp = fopen('php://output', 'a');
    // 输出Excel列头信息 
    $head = array('ID','xxx');
    //字符替换
    $p_new_lines = array("\r\n", "\n","\t","\r","\r\n", "<pre>","</pre>","<br>","</br>","<br/>");
    $p_change_line_in_excel_cell = '';
    echo "<table>";
    echo "<tr>";
    foreach($head as $v){
      echo "<td>".iconv('utf-8','gb2312',$v)."</td>";
    }
    echo "</tr>";
    // 逐行取出数据,节约内存
    while ($res = mysql_fetch_assoc($query)) {
      echo "<tr>";
      echo "<td style='vnd.ms-excel.numberformat:@'>".$res['id']."</td>";
      echo "<td>".iconv('utf-8', 'gb2312', $res['xxx']."</td>";
      echo"</tr>";
    }
    echo "</table>";
  }

以上这篇php原生导出excel文件的两种方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。

以上就是本次给大家分享的全部知识点内容总结,大家还可以在下方相关文章里找到vue项目中使用md5加密以及、 详解vue axios封装请求状态、 儿童python编程入门书籍推、 等php文章进一步学习,感谢大家的阅读和支持。

上一篇:Laravel实现表单提交的实例代码详解

下一篇:composer错误使用的问题与解决方法

展开 +

收起 -

学习笔记
网友NO.423519

PHPExcel在linux环境下导出报500错误的解决方法

原先我导出为 XLSX 格式,用的是 $objWriter = IOFactory::createWriter($objPHPExcel, 'Excel2007'); 报错,纠结就纠结在,在开发环境和测试环境都没问题,放在生产环境直接 500 错误。 后来我改成导出 XLS 格式, $objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5'); 问题解决了,具体为什么待有空了研究下!!! 以上这篇PHPExcel在linux环境下导出报500错误的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。 ……

网友NO.528604

PHPExcel导入Excel表格到MySQL数据库的简单实例详解

如下所示: ?phpdefine(BASE_URL, realpath(dirname(__FILE__)));require_once BASE_URL . /PHPExcel/PHPExcel.php;//引入PHPExcel类文件//excel文件的地址$excel_fiel_path = ./phpexcel.xls;$PHPExcel = new PHPExcel();// 实例化PHPExcel工具类//分析文件获取后缀判断是2007版本还是2003$extend = pathinfo(./ . $excel_fiel_path);$extend = strtolower($extend[extension]); // 判断xlsx版本,如果是xlsx的就是2007版本的,否则就是2003if ($extend==xlsx) { $PHPReader = new PHPExcel_Reader_Excel2007(); $PHPExcel = $PHPReader-load(./ . $excel_fiel_path);}else{ $PHPReader = new PHPExcel_Reader_Excel5(); $PHPExcel = $PHPReader-load(./ . $excel_fiel_path);} /* 第二种方法*/$objWorksheet = $PHPExcel-getActiveSheet();$highestRow = $objWorksheet-getHighestRow(); echo highestRow=.$highestRow;echo br;$highestColumn = $objWorksheet-getHighestColumn();$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);//总列数echo highestColumnIndex=.$highestColumnIndex;echo br;$headtitle=array(); for ($row = 2;$row = $highestRow;$row++) { $strs=array(); //注意highestColumnIndex的列数索引从0开始 for ($col = 0;$col $highestColumnIndex;$col++) { $strs[$col] =$objWorksheet-getCellByColumnAndRow($col, $row)-getValue(); } //todo //连接mysql ,一条条写入 } ……

网友NO.511300

PHPExcel笔记, mpdf导出

phpexcel常用处理 ##导入类库require 'PHPExcel/Classes/PHPExcel.php';require 'PHPExcel/Classes/PHPExcel/Writer/Excel5.php'; //非07格式的写出类 ##基础属性设定$objPHPExcel = \PHPExcel_IOFactory::load('a.xls'); //读入指定excel文件$objPHPExcel-setActiveSheetIndex(0); //指定活动工作表$objPHPExcel-getActiveSheet()-getDefaultStyle()-getFont()-setName('宋体');$objPHPExcel-getProperties()-setTitle('xxx'); ##单元格编辑$objPHPExcel-getActiveSheet()-setCellValue('A3', 'xxx'); //设定A3单元格值为xxx ##单元格绘图$objDrawing = new \PHPExcel_Worksheet_Drawing();$objDrawing-setPath('a.jpg'); //指定图片路径。若要远程图片需PHPExcel/Classes/PHPExcel/Worksheet/Drawing.php:106处file_exists换成file_get_contents$objDrawing-setCoordinates('A4'); //指定在A4单元格绘图$objDrawing-setName('Photo');$objDrawing-setDescription('Photo');$objDrawing-setHeight(120);$objDrawing-setWidth(100);$objDrawing-setOffsetX(7);$objDrawing-setOffsetY(7);$objDrawing-setWorksheet($objPHPExcel-getActiveSheet()); ##excel文件浏览器下载导出$filename='a.xls';$encoded_filename = rawurlencode($filename);$ua = $_SERVER["HTTP_USER_AGENT"];header('Content-type: application/vnd.ms-excel');if (preg_match("/MSIE/", $ua) || preg_match("/Trident\/7.0/", $ua) || preg_match("/Edge/", $ua)) { header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');} else if (preg_match("/Firefox/", $ua)) { header("Content-Disposition: attachment; filen……

网友NO.851547

PHP实现仿百度文库,豆丁在线文档效果(word,excel,ppt转flash)

本文实例讲述了PHP实现仿百度文库,豆丁在线文档效果。分享给大家供大家参考,具体如下: 由于项目要实现类似百度文库的功能,又是我一个人做的项目,所以就想到找免费的现成的来使用。在网上找到的都是一样的。如下: Flash Paper支持Office文档(.doc,.xls,.ppt)直接转换为PDF或SWF,速度很快,效果较好。可惜,Flash Paper V2.2后没有再更新了。安装Flash Paper后,可以直接使用命令调用FlashPrinter.exe,实现批量转换。 例如:C:\FlashPaper2.2\FlashPrinter.exe C:\Flex技术简介.ppt -o C:\Flex技术简介.swf 下载个FlashPaper,安装好之后,控制面板的打印机那里会出现一个虚拟的打印机,这个就说明安装成功了,win7下我试过32位的和64位的都安装不了。 在命令行试一下上面的命令,路径根据自身调整。执行后,成功就说明可以用了. 接下来就是php使用了,php使用 exec,或者system等来执行cmd命令,如: exec("C:\FlashPaper2.2\FlashPrinter.exe C:\Flex技术简介.ppt -o C:\Flex技术简介.swf"); 执行这个之前要配置以下php.ini 把安全模式设为off(safe_mode = Off),或者开着也行,在safe_mode_exec_dir =设置允许允许exe的路径,设为flashpaer的路径。 测试一下,执行成功! 这 些都是可以在网上查到的,由于我用的是office2007所以word后缀.docx,转换的时候就失败了,一直在网上也找不到原因,无意中……

<
1
>

Copyright 2018-2019 xz577.com 码农之家

版权责任说明