设为首页 收藏本站
查看: 1354|回复: 0

[经验分享] FollowYou_博客

[复制链接]

尚未签到

发表于 2017-12-29 12:39:11 | 显示全部楼层 |阅读模式
PHP导出Excel
phpphpExcel导出excel  这些天在使用PHPExcel导出数据时,5000条数据竟然挂了。后来跟同事聊聊,有些明悟,PHPExcel做了很多处理,我在这里理解为渲染,就会暂用过多的空间,‘膨胀’的空间导致内存暂用过大,就挂了。其实只要我们只是简单的导出操作,没有必要使用PHPExcel。大牛给了我这个程序,还没搞清楚原理(如果有小伙伴知道,请不吝赐教哦!),贴出代码:

  • /*
  • *处理Excel导出
  • *@param $datas array 设置表格数据
  • *@param $titlename string 设置head
  • *@param $title string 设置表头
  • */
  • public function excelData($datas,$titlename,$title,$filename){
  •     $str = "<html xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\nxmlns:x=\"urn:schemas-microsoft-com:office:excel\"\r\nxmlns=\"http://www.w3.org/TR/REC-html40\">\r\n<head>\r\n<meta http-equiv=Content-Type content=\"text/html; \">\r\n</head>\r\n<body>";
  •     $str .="<table border=1><head>".$titlename."</head>";
  •     $str .= $title;
  •     foreach ($datas  as $key=> $rt )
  •     {
  •         $str .= "<tr>";
  •         foreach ( $rt as $k => $v )
  •         {
  •             $str .= "<td>{$v}</td>";
  •         }
  •         $str .= "</tr>\n";
  •     }
  •     $str .= "</table></body></html>";
  •     header( "Content-Type: application/vnd.ms-excel; name='excel'" );
  •     header( "Content-type: application/octet-stream" );
  •     header( "Content-Disposition: attachment; filename=".$filename );
  •     header( "Cache-Control: must-revalidate, post-check=0, pre-check=0" );
  •     header( "Pragma: no-cache" );
  •     header( "Expires: 0" );
  •     exit( $str );
  • }

  原理不是太懂,就是将html的表格转换excel的表格;此种方法适应于设置各种单元格的显示,合并,只需设置html的table,设置css就能导出各式各样的excel模板。
  实例如下:
  导出一个带表头,表头带颜色,设置字体大小,居中,排版适中;

  • $dataResult = array();      //todo:导出数据(自行设置)
  • $headTitle = "XX保险公司 优惠券赠送记录";
  • $title = "优惠券记录";
  • $headtitle= "<tr style='height:50px;border-style:none;><th border=\"0\" style='height:60px;width:270px;font-size:22px;' colspan='11' >{$headTitle}</th></tr>";
  • $titlename = "<tr>
  •                <th style='width:70px;' >合作商户</th>
  •                <th style='width:70px;' >会员卡号</th>
  •                <th style='width:70px;'>车主姓名</th>
  •                <th style='width:150px;'>手机号</th>
  •                <th style='width:70px;'>车牌号</th>
  •                <th style='width:100px;'>优惠券类型</th>
  •                <th style='width:70px;'>优惠券名称</th>
  •                <th style='width:70px;'>优惠券面值</th>
  •                <th style='width:70px;'>优惠券数量</th>
  •                <th style='width:70px;'>赠送时间</th>
  •                <th style='width:90px;'>截至有效期</th>
  •            </tr>";
  •            $filename = $title.".xls";
  •        $this->excelData($dataResult,$titlename,$headtitle,$filename);
  提供案列供参考,具体程序可以做更好的封装处理。
  加油各位,加油自己,天行健!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-429329-1-1.html 上篇帖子: php写购物车(思路&源码) 下篇帖子: php 接口与前端数据交互实现
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表