PHP利用网络协议直接导出数据到Excel表格

皓月 主页  | PHP 2018-10-12

拿走系列,直接上代码:


    /**
    * 导出数据至Excel
    * @author Aihy
    * @email 202683457@qq.com
    */
   public function outputData()
   {
       // 导出文件名
       $excelName = 'Excel文件名';
       
// 导出数据(二维数组)        
       $excelData = array(
           array(1024,'http://www.7l7y.com','7Y'),
           array(2048,'http://www.aihy.top','7Y'),
       );
       
// 生成Excel文件        
       $this->_exportexcel($excelData,array('编号','网址','备注'),$excelName);
   }


    /**
    * 导出数据为excel表格
    * @param array $data              一个二维数组,结构如同从数据库查出来的数组
 * @param array $title               excel的第一行标题,一个数组,如果为空则没有标题
 * @param string $filename      下载的文件名
 * @author Aihy
    * @email 202683457@qq.com
    */
   public function _exportExcel($data = array() , $title = array() , $filename='report')
   {
       header("Content-Type: text/html; charset=UTF-8");
       header("Content-type:application/octet-stream");
       header("Accept-Ranges:bytes");
       header("Content-type:application/vnd.ms-excel");
       header("Content-Disposition:attachment;filename=".$filename.".xls");
       header("Pragma: no-cache");
       header("Expires: 0");
       // 导出xls 开始
  if (!empty($title))
       {
           foreach ($title as $k => $v)
           {
               $title[$k] = iconv("UTF-8", "GB2312",$v);
           }
           $title= implode("\t", $title);
           echo "$title\n";
       }
       if (!empty($data))
       {
           foreach($data as $key => $val)
           {
               foreach ($val as $ck => $cv)
               {
                   $data[$key][$ck] = iconv("UTF-8", "GB2312", $cv);
               }
               $data[$key] = implode("\t", $data[$key]);
           }
           echo implode("\n",$data);
       }
   }


最终输出结果如下:


导出文件:

image.png

Excel内容:

image.png


阅读 29556
24
扫描关注 | 夜与 | 路漫漫其修远兮

微信扫一扫
关注该公众号

返回顶部
ICP: 渝ICP备19001894号-4