php 自定义函数实现将数据 以excel 表格形式导出示例

这篇文章主要介绍了php 自定义函数实现将数据 以excel 表格形式导出,结合实例形式分析了PHP操作二维数组的遍历与Excel格式输出相关实现技巧,需要的朋友可以参考下.

本文实例讲述了php 自定义函数实现将数据 以excel 表格形式导出,分享给大家供大家参考,具体如下:

  1. /**
  2. * 导出数据为excel表格
  3. * @param
  4. * array $data 一个二维数组,结构如同从数据库查出来的数组
  5. * array $title excel的第一行标题,一个数组,如果为空则没有标题
  6. * String $filename 下载的文件名
  7. */
  8. function exportexcel($data=array(),$title=array(),$filename='report'){
  9. header("Content-type:application/octet-stream");
  10. header("Accept-Ranges:bytes");
  11. header("Content-type:application/vnd.ms-excel");
  12. header("Content-Disposition:attachment;filename=".$filename.".xls");
  13. header("Pragma: no-cache");
  14. header("Expires: 0");
  15. //导出xls 开始
  16. if (!emptyempty($title)){
  17. foreach ($title as $k => $v) {
  18. $title[$k]=iconv("UTF-8", "GB2312",$v);
  19. }
  20. $title= implode("\t", $title);
  21. echo "$title\n";
  22. }
  23. if (!emptyempty($data)){
  24. foreach($data as $key=>$val){
  25. foreach ($val as $ck => $cv) {
  26. $data[$key][$ck]=mb_convert_encoding($cv,"GB2312","UTF-8");
  27. }
  28. $data[$key]=implode("\t", $data[$key]);
  29. }
  30. echo implode("\n",$data);
  31. }
  32. }

php内置函数讲解

String mb_convert_encoding( $str, $encoding1,$encoding2 )

$str,要转换编码的字符串

$encoding1,目标编码,如utf-8,gbk,大小写均可

$encoding2,原编码,如utf-8,gbk,大小写均可

demo

$title = array("title1","title2","title3");

$data = array("数据1","数据2","数据3");

$fileName = "demo";

exportexcel($data,$title,$fileName);