本文引自网络,仅供自己学习之用。

利用php导出excel我们大多会直接生成.xls文件,这种方便快捷。

  1. function createtable($list,$filename){
  2. header("Content-type:application/vnd.ms-excel");
  3. header("Content-Disposition:filename=".$filename.".xls");
  4. $strexport="编号\t姓名\t性别\t年龄\r";
  5. foreach ($list as $row){
  6. $strexport.=$row['id']."\t";
  7. $strexport.=$row['username']."\t";
  8. $strexport.=$row['sex']."\t";
  9. $strexport.=$row['age']."\r";
  10. }
  11. $strexport=iconv('UTF-8',"GB2312//IGNORE",$strexport);
  12. exit($strexport);
  13. }

基于这个我们可以将方法封装一下:

  1. /**
  2. * 创建(导出)Excel数据表格
  3. * @param  array   $list 要导出的数组格式的数据
  4. * @param  string  $filename 导出的Excel表格数据表的文件名
  5. * @param  array   $header Excel表格的表头
  6. * @param  array   $index $list数组中与Excel表格表头$header中每个项目对应的字段的名字(key值)
  7. * 比如: $header = array('编号','姓名','性别','年龄');
  8. *       $index = array('id','username','sex','age');
  9. *       $list = array(array('id'=>1,'username'=>'YQJ','sex'=>'男','age'=>24));
  10. * @return [array] [数组]
  11. */
  12. protected function createtable($list,$filename,$header=array(),$index = array()){
  13. header("Content-type:application/vnd.ms-excel");
  14. header("Content-Disposition:filename=".$filename.".xls");
  15. $teble_header = implode("\t",$header);
  16. $strexport = $teble_header."\r";
  17. foreach ($list as $row){
  18. foreach($index as $val){
  19. $strexport.=$row[$val]."\t";
  20. }
  21. $strexport.="\r";
  22. }
  23. $strexport=iconv('UTF-8',"GB2312//IGNORE",$strexport);
  24. exit($strexport);
  25. }

方法调用:

  1. $filename = '提现记录'.date('YmdHis');
  2. $header = array('会员','编号','联系电话','开户名','开户行','申请金额','手续费','实际金额','申请时间');
  3. $index = array('username','vipnum','mobile','checkname','bank','money','handling_charge','real_money','applytime');
  4. $this->createtable($cash,$filename,$header,$index);

运行就可以得到表格:


这种方式生成Excel文件,生成速度很快,但是有缺点是:
1.单纯的生成Excel文件,生成的文件没有样式,单元格属性(填充色,宽度,高度,边框颜色...)不能自定义;
2.生成的文件虽然可以打开,但是兼容性很差,每次打开,都会报一个警告:

解决这个问题也不难,具体参见:使用PHPExcel实现Excel文件的导入和导出

PHP生成excel表格文件并下载的更多相关文章

  1. Java操作Jxl实现导出数据生成Excel表格数据文件

    实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...

  2. php中读写excel表格文件示例。

    测试环境:php5.6.24.这块没啥兼容问题. 需要更多栗子,请看PHPExcel的examples.还是蛮强大的. 读取excel文件. 第一步.下载开源的PHPExcel的类库文件,官方网站是h ...

  3. H5纯前端生成Excel表格

    H5纯前端生成Excel表格方法如下: <!DOCTYPE html> <html> <head> <title></title> < ...

  4. Jmeter—生成excel结果文件

    相信很多用jmeter进行接口测试的童鞋都会有这样的苦恼:同时执行上百条测试案例,如何能轻松加愉快地检查案例输出结果?仅仅靠jmeter的断言.debug sampler.察看结果树等是无法满足我们要 ...

  5. pyhton读取 excel表格文件

    2019的第一天,忘记昨日之事,迎接新的明天. excel表格文件办公中常用,如通过Python操作这些数据需导入并有序读取这些数据 特随笔,供以后查阅 代码如下: import xlrd # fil ...

  6. JXL生成Excel,并提供下载(2:提供下载)

    实现效果: 项目中使用JXL生成Excel,使生成的Excel可以让用户下载,如下图 一.生成Excel 二.提供下载 实现思路: 1.页面使用form表单提交方式(Ajax提交方式,我这里不行) 2 ...

  7. python读取Excel表格文件

    python读取Excel表格文件,例如获取这个文件的数据 python读取Excel表格文件,需要如下步骤: 1.安装Excel读取数据的库-----xlrd 直接pip install xlrd安 ...

  8. 详解python操作生成excel表格,并且填充数据

    最近在研究python操作excel表格的问题,首先读取excel表格觉得平时用的多,不怎么有难度,就是pyhon生成excel表格的时候,平时不怎么用,所以重点研究了一下,现总结如下: 1.首先用到 ...

  9. 简单Excel表格上传下载,POI

    一.废话 Excel表格是office软件中的一员,几乎是使用次数最多的办公软件.所以在java进行企业级应用开发的时候经常会用到对应的上传下载便利办公. 目前,比较常用的实现Java导入.导出Exc ...

随机推荐

  1. C# 往线程里传参数的方法总结

    Thread (ParameterizedThreadStart) 初始化 Thread 类的新实例,指定允许对象在线程启动时传递给线程的委托.   Thread (ThreadStart) 初始化 ...

  2. Oracle TO_DATE() 函数格式化时间【全】

    TO_DATE格式(以时间:2007-11-02   13:45:25为例)          Year:             yy two digits 两位年                显 ...

  3. 关于电脑重装win10系统导致编译环境失效(jdk)

    年前换了固态,于是重装了系统发现之前装在非系统盘的jdk1.8配置过系统环境后仍然不能正常使用的问题,在犹豫一会后选择了重装jdk, 由于之前用的是win7在环境配置上是 变量值内加;即可自行分行,但 ...

  4. Listary Pro- 文件浏览与搜索增强的超级神器

    Listary 是一款 Windows 文件浏览增强工具,为 Windows 资源管理器增加智能命令.最近文档以及收藏功能.文件小,功能强大.秒杀系统自带搜索功能!! 它是一款非常优秀的 Window ...

  5. Mysql数据库 的库表简易操作

    一. 库的操作 1.创建数据库 创建数据库: create database 库名 charset utf8;   charset uft8  可选项 1.2 数据库命名规范: 可以由字母.数字.下划 ...

  6. unity 获取水平FOV

    unity中Camera的Field of View是指的垂直FOV,水平FOV可以经过计算得到. 创建脚本如下,把脚本挂载到摄像机上即可得到水平FOV: public class GetHorizo ...

  7. apktool逆向apk包

    在AndroidStudio创建so一节里创建了so,并且在java里面调用so的HelloWorld方法,编译Android Studio后生成包app-debug.apk. 在逆向apk时如果该a ...

  8. Android逆向 APK文件组成

    一 了解APK文件 我们知道Android系统能运行的程序是.apk文件格式,其实它就是一个压缩包而已,把.apk修改成.zip,然后解压就可以得到该apk内部的文件结构. PS: 既然可以把apk文 ...

  9. DOS中的ECHO命令详解

    1. 作为控制批处理命令在执行时是否显示命令行自身的开关  格式:ECHO [ON|OFF]  如果想关闭“ECHO OFF”命令行自身的显示,则需要在该命令行前加上“@”.  2. 显示当前ECHO ...

  10. (个人记录)Python2 与Python3的版本区别

    现在还有些开源模块还没有更新到python3 ,不了解版本区别,无法对不合适的地方进行更改. 由于只追求向Python3靠近,所以对于python2的特别用法不探究. 此文不补全所有版本区别,仅作档案 ...