利用php下载xls文件(自己动手写的)


Posted in PHP onApril 18, 2014

昨天看ECSHOP源码的时候,碰到了一点自己没有学过的只是--如何利用php实现下载xls文件。根据它的源码,我动手实现了一下,成功实现了这个效果。

源码:

<?php 
/* 
*@Description:下载xls表 
* 
* 
*/ 
function downloadXls($filename=''){ 
$filename = !empty($filename) ? $filename : die('nothing'); //header 的作用是 新建一个被下载的test.xls 
header("Content-Type: application/vnd.ms-excel; charset=utf8"); 
header("Content-Disposition: attachment; filename=$filename"); 
//这里需要被输出的内容直接输出到test.xls文件中 
echo 'This is the test!'; 
exit; 
} 
$fileName = 'test.xls'; 
downloadXls($fileName); 
?>

效果:

利用php下载xls文件(自己动手写的) 

注意:如果输出的是中文信息的话,要注意字符编码的格式转换!

但如果我想下载的是服务器中保存的xls文件呢?

经过查看php手册:发现很简单就可以实现这个功能了,使用到了一个 readfile函数 。代码如下:

<?php 
/* 
*@Description:下载xls表 
* 
* 
*/ 
function downloadXls($filename=''){ 
$filename = !empty($filename) ? $filename : die('nothing'); //header 的作用是 新建一个被下载的test.xls 
header("Content-Type: application/vnd.ms-excel; charset=utf8"); 
header("Content-Disposition: attachment; filename=$filename"); 
//这里是需要被输出的文件 
readfile($filename); 
} 
$fileName = 'test.xls'; 
downloadXls($fileName); 
?>

效果:

利用php下载xls文件(自己动手写的) 

再拓展一下:如果我想下载的是一个txt文件呢,pdf文件呢?

实现的方法就是修改header 输出中的Content-Type中的内容!

有什么不多的地方,请大神指出!

PHP 相关文章推荐
php4的彩蛋
Oct 09 PHP
PHP语法速查表
Jan 02 PHP
用php将任何格式视频转为flv的代码
Sep 03 PHP
PHP 数组遍历方法大全(foreach,list,each)
Jun 30 PHP
PHP PDOStatement:bindParam插入数据错误问题分析
Nov 13 PHP
一个经典的PHP验证码类分享
Nov 18 PHP
C# WinForm中实现快捷键自定义设置实例
Jan 23 PHP
php+ajax制作无刷新留言板
Oct 27 PHP
php+ajax实现异步上传文件或图片功能
Jul 18 PHP
PHP实现的简单sha1加密功能示例
Aug 27 PHP
PHP实现将base64编码字符串转换成图片示例
Jun 22 PHP
php实现分页功能的详细实例方法
Sep 29 PHP
php生成随机字符串可指定纯数字、纯字母或者混合的
Apr 18 #PHP
从PHP的源码中深入了解stdClass类
Apr 18 #PHP
理解PHP中的stdClass类
Apr 18 #PHP
php使用imagick模块实现图片缩放、裁剪、压缩示例
Apr 17 #PHP
php实现的漂亮分页方法
Apr 17 #PHP
codeigniter中测试通过的分页类示例
Apr 17 #PHP
php生成静态页面的简单示例
Apr 17 #PHP
You might like
也谈 PHP 和 MYSQL
2006/10/09 PHP
一个取得文件扩展名的函数
2006/10/09 PHP
php heredoc和phpwind的模板技术使用方法小结
2008/03/28 PHP
php 无限级分类,超级简单的无限级分类,支持输出树状图
2014/06/29 PHP
PHP大批量插入数据库的3种方法和速度对比
2014/07/08 PHP
php备份数据库类分享
2015/04/14 PHP
PHP抓取及分析网页的方法详解
2016/04/26 PHP
JavaScript DOM 学习第五章 表单简介
2010/02/19 Javascript
一个简单的JS鼠标悬停特效具体方法
2013/06/17 Javascript
阻止事件(取消浏览器对事件的默认行为并阻止其传播)
2013/11/03 Javascript
详解JavaScript中localStorage使用要点
2016/01/13 Javascript
javascript中apply、call和bind的使用区别
2016/04/05 Javascript
基于JS实现密码框(password)中显示文字提示功能代码
2016/05/27 Javascript
浅谈js内置对象Math的属性和方法(推荐)
2016/09/19 Javascript
javascript实现图片左右滚动效果【可自动滚动,有左右按钮】
2016/09/19 Javascript
js+canvas实现动态吃豆人效果
2017/03/22 Javascript
JavaScript实现简单的树形菜单效果
2017/06/23 Javascript
JS使用tofixed与round处理数据四舍五入的区别
2017/10/25 Javascript
使用vue官方提供的模板vue-cli搭建一个helloWorld案例分析
2018/01/16 Javascript
javascript设计模式 ? 中介者模式原理与用法实例分析
2020/04/20 Javascript
微信小程序onShareTimeline()实现分享朋友圈
2021/01/07 Javascript
[05:56]第十六期——新进3大C之小兔基
2014/06/24 DOTA
[00:52]DOTA2齐天大圣预告片
2016/08/13 DOTA
[00:59]DOTA2背景故事第二期之四大基本法则
2020/07/07 DOTA
Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
2018/04/30 Python
深入了解Django View(视图系统)
2019/07/23 Python
在django中,关于session的通用设置方法
2019/08/06 Python
关于探究python中sys.argv时遇到的问题详解
2021/02/23 Python
专门出售各种儿童读物的网站:Put Me In The Story
2016/08/07 全球购物
大学同学聚会邀请函
2014/01/19 职场文书
4S店售后客服自我评价
2014/04/09 职场文书
关于诚信的活动方案
2014/08/18 职场文书
解放思想演讲稿
2014/09/11 职场文书
四风问题对照检查材料思想汇报
2014/10/07 职场文书
四风问题自查自纠工作情况报告
2014/10/28 职场文书
上手简单,功能强大的Python爬虫框架——feapder
2021/04/27 Python