thinkphp导出csv文件,用表格输出excel

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 1.thinkphp导出csv文件 导出csv文件可能就那几行代码,今天有个问题困扰我好久,就是导出之后出现一些html代码,这个不应该,view里面是空的,controller中最后也没有$this->display(),最后细心看到think_page_trace这样的字样,恍然大悟,是页面的跟踪日志,这个默认是会输出来的。

1.thinkphp导出csv文件

导出csv文件可能就那几行代码,今天有个问题困扰我好久,就是导出之后出现一些html代码,这个不应该,view里面是空的,controller中最后也没有$this->display(),最后细心看到think_page_trace这样的字样,恍然大悟,是页面的跟踪日志,这个默认是会输出来的。最后在方法后面加了一个exit结束就好了,下面是代码:

1.IndexController.class.php

<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {

    public function index(){
        $hotel = M('keywords')->field('PageName,Page')->select();
        $str = "关键字,名称\n";
        $str = iconv('utf-8','gb2312',$str);
        $result = mysql_query("select PageName,Page from hotel_keywords");
        while($row=mysql_fetch_array($result)){
            $PageName = iconv('utf-8','gb2312',$row['PageName']);
            $Page = iconv('utf-8','gb2312',$row['Page']);
            $str .= $PageName.",".$Page."\n";
        }
        $fileName = date('Ymd').'.csv';
        $model = D('Keywords');
        $model->export_csv($fileName,$str);
        exit;
    }
}

2.KeywordsModel.class.php

<?php 
namespace Home\Model;

use Think\Model;

class KeywordsModel extends Model{
    
    public function export_csv($filename, $data){
        header("Content-type:text/csv");   
        header("Content-Disposition:attachment;filename=".$filename);   
        header('Cache-Control:must-revalidate,post-check=0,pre-check=0');   
        header('Expires:0');   
        header('Pragma:public');
        echo $data;
        
    }
}

奥妙就在IndexController.class.php代码最后一句的exit这里,如果不写这句,输出的excel里面有html源码,截图如下:

 

2.用表格输出excel

如下代码purchase_prospects.php

<?php
require('page_header.php');

$site_id = getIfSet($_GET, 'site_id', 0);
$customer_type = getIfSet($_GET, 'customer_type',0);
$DB = Database::connect($site_id);

if($site_id>0 && $customer_type>0){
    $sql = '';
    $out = '';    
    $short_name_array = SiteSettings::$SITE_SHORT_NAME;
    $short_name = $short_name_array[$site_id]; 
    
    switch ($customer_type) {
        case '1':{
            $sql = "SELECT 
                        email, CONCAT(UCASE(LEFT(firstname, 1)),SUBSTRING(firstname, 2)) AS firstname, CONCAT(UCASE(LEFT(lastname, 1)),SUBSTRING(lastname, 2)) AS lastname 
                    FROM customers 
                    WHERE site_id =$site_id 
                        AND email NOT REGEXP '.+(avanquest)|(planetart)|(novadevelop)|(qatest).+' 
                        AND email IN(SELECT a.email FROM customers a INNER JOIN orders b ON a.id=b.`customer_id` AND b.is_test=0 AND a.site_id =$site_id) 
                        AND email NOT IN (SELECT email_address FROM `newsletter_unsubscribes` WHERE site_id =$site_id);";
            $res = $DB->query($sql);
            $out = '<table class="data_table"><tr><th>email</th><th>firstname</th><th>lastname</th></tr>';
            while($row = mysql_fetch_array($res)){
                $out .= '<tr><td>'.$row['email'].'</td><td>'.$row['firstname'].'</td><td>'.$row['lastname'].'</td></tr>';
            }
            $short_name .= '_purchased';
            break;
        }
        case '2':{
            $DB->query("DROP TEMPORARY TABLE IF EXISTS tmp_purchase;");
            $DB->query("CREATE TEMPORARY TABLE tmp_purchase SELECT a.email FROM customers a INNER JOIN orders b ON a.id=b.`customer_id` AND b.is_test=0 AND a.site_id =$site_id; ");
            $DB->query("DROP TEMPORARY TABLE IF EXISTS tmp_nopurchase;");
            $DB->query("CREATE TEMPORARY TABLE tmp_nopurchase SELECT email FROM customers WHERE site_id =$site_id AND email NOT IN(SELECT email FROM tmp_purchase);");
            if(9 != $site_id){
                $datatype = SiteSettings::getPurchaseDataType($site_id);
                $DB->query("INSERT tmp_nopurchase SELECT DISTINCT email FROM triggered_email_data WHERE datatype='$datatype' AND email NOT IN(SELECT email FROM tmp_purchase);");
            }
            $sql = "SELECT DISTINCT email FROM tmp_nopurchase WHERE email NOT REGEXP '.+(avanquest)|(planetart)|(novadevelop)|(qatest).+' AND Email REGEXP '[A-Z0-9._%-]+@[A-Z0-9.-]+\.[A-Z]{2,4}$' AND email NOT IN (SELECT email_address FROM `newsletter_unsubscribes` WHERE site_id =$site_id);";
            $res = $DB->query($sql);
            $out = '<table class="data_table"><tr><th>email</th></tr>';
            while($row = mysql_fetch_array($res)){
                $out .= '<tr><td>'.$row['email'].'</td></tr>';
            }
            $short_name .= '_non-purchased and signup';
            break;
        }
        default:
            break;
    }

    $out .= '</table>';
    header("Content-type:application/vnd.ms-excel");
    header("Content-Disposition:filename=$short_name.xls");
    echo $out;
    exit;
}
?>
<h1>Purchase Prospects Report</h1>
<form name="frm" method="get" action="purchase_prospects.php">
<strong>Select Site:</strong> 
<select name="site_id" id="site_id">
    <option value="0">== select site ==</option>
    <option value="1">STI</option>
    <option value="2">PA</option>
    <option value="3">CW</option>
    <option value="6">MCC</option>
    <option value="9">CB</option>
    <option value="4">STIUK</option>
    <option value="8">MCCUK</option>
</select> &nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;
<strong>Select Type:</strong>
<select id="customer_type" name="customer_type">
    <option value="0">== select type ==</option>
    <option value="1">purchased</option>
    <option value="2">non-purchased and signup</option>
</select>
&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;
<input id="submit" type="submit" value="Run &raquo;">
</form>
<script type="text/javascript">
    $(function(){
        $("#submit").click(function(){
            if('0' == $("#site_id").val() || '0' == $("#customer_type").val()){
                alert('please select Site and Site');
                return false;
            }
        })
    });
</script>

这样也可以导出ecxcel文件,截图如下

依然注意最后一句exit;如果没有这一句,excel里面会有一些页面元素。

 

作者:Tyler Ning
出处:http://www.cnblogs.com/tylerdonet/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过以下邮箱地址williamningdong@gmail.com  联系我,非常感谢。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
123 5
|
13天前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分到不同的工作表中。本文通过一个示例代码展示了如何生成一个包含总成绩表和三个班级表的Excel文件。代码首先创建了一个包含学生姓名、班级和各科成绩的数据框,然后按班级分组,将每个班级的数据分别写入不同的工作表。最后,生成的Excel文件将包含四个工作表,分别为总成绩表和三个班级的成绩表。
23 6
按条件将Excel文件拆分到不同的工作表
|
12天前
|
Python
批量将不同的工作簿合并到同一个Excel文件
本文介绍如何使用Python的`pandas`库批量合并不同工作簿至同一Excel文件。通过模拟生成三个班级的成绩数据,分别保存为Excel文件,再将这些文件合并成一个包含所有班级成绩的总成绩单。步骤包括安装必要库、生成数据、保存与合并工作簿。
21 6
|
12天前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分为多个工作表。本文通过一个具体示例,展示了如何根据学生班级将成绩数据拆分到不同的工作表中,并生成一个包含总成绩表和各班级成绩表的Excel文件。代码简洁明了,适合初学者学习和应用。
27 6
|
20天前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
25 1
|
22天前
|
数据格式 UED
记录一次NPOI库导出Excel遇到的小问题解决方案
【11月更文挑战第16天】本文记录了使用 NPOI 库导出 Excel 过程中遇到的三个主要问题及其解决方案:单元格数据格式错误、日期格式不正确以及合并单元格边框缺失。通过自定义单元格样式、设置数据格式和手动添加边框,有效解决了这些问题,提升了导出文件的质量和用户体验。
143 3
|
1月前
|
SQL 数据可视化 数据挖掘
想让Excel表格设计更美观?试试这几款好用工具!
Excel表格设计在项目管理和数据分析中至关重要。本文推荐四款辅助工具:板栗看板、Excel自动图表助手、Think-Cell Chart 和 Power BI,分别在任务管理、图表生成、数据可视化等方面表现突出,帮助你设计出更专业、美观的表格。
58 2
|
1月前
|
Java API Apache
|
1月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
43 4
|
13天前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####