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

摘要:
phpnamespaceHomeController;使用ThinkController;ClassIndexControllerextendsController{publicfunctionindex(){$hotel=M-˃field-˃select();$str=“关键字,名称”;$str=iconv;$result=mysql_query;而{$PageName=iconv,$Page=iconvfileName=date.'。csv';$型号=D;$型号-˃导出.csv;退出;}}2.关键字Model.class。php˂?phpnamespaceHomeModel;使用思维模型;classKeywordsModelextendsModel{publicfunctionexport_csv{header;header;head;header;header,echo$data;}}秘密在于IndexController。class这里是php代码最后一句的出口。如果没有写这句话,html源代码将包含在输出excel中。屏幕截图如下:2.使用表格输出excel,如下所示:purchase_prospect.php˂?

1.thinkphp导出csv文件

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

1.IndexController.class.php

<?php
namespace HomeController;
use ThinkController;
class IndexController extends Controller {

    public function index(){
        $hotel = M('keywords')->field('PageName,Page')->select();
        $str = "关键字,名称
";
        $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."
";
        }
        $fileName = date('Ymd').'.csv';
        $model = D('Keywords');
        $model->export_csv($fileName,$str);
        exit;
    }
}

2.KeywordsModel.class.php

<?php 
namespace HomeModel;

use ThinkModel;

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源码,截图如下:

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

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   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   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文件,截图如下

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

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

免责声明:文章转载自《thinkphp导出csv文件,用表格输出excel》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇核心Swing组件(七)DotnetBrowser入门教程-入门下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

postgresql 查看用户名

查看当前连接的用户名:  foo=#select * from current_user; 或 foo=#select user; 查看所有用户名:  foo=#du 用户管理可以查看之前的博文: https://www.cnblogs.com/ryanzheng/p/9427126.html...

CSS之user-select——设置标签中的文字是否可被复制

  详细介绍请参考 http://www.css88.com/book/css/properties/user-interface/user-select.htm   CSS样式 user-select:none | text | all | element,默认情况下是text,表示标签中的文字可以被复制,none是不可被复制。   为了兼容各种浏览器,...

CSV文件在服务器上直接导入hive

如何把CSV文件导入hive CSV文件实例(scuba.csv,文件是逗号分割的): DzDBNW,然后规定主要,男,不要等级管理,blqnIT,学生记者说明 1.准备hive建表语句,因为csv文件是逗号分割,所以建表语句需要指定分割符和类型 CREATE TABLE CSV_SCUBA ( xxx,xxx )row format delimited...

MongoDB/备份

mongodump: 在MongoDB中我们使用mongodump命令来备份MongoDB数据。该命令可以导出所有数据到指定目录中。./bin/mongodump -h dbhost -d dbname -o yourdirectory./bin/mongodump --host mongodb.example.net --port 27017 --d...

Mysql 日期时间类型详解

MySQL 中有多种数据类型可以用于日期和时间的表示,不同的版本可能有所差异,表3-2 中列出了MySQL 5.0 中所支持的日期和时间类型。 这些数据类型的主要区别如下: * 如果要用来表示年月日,通常用DATE 来表示。 * 如果要用来表示年月日时分秒,通常用DATETIME 表示。 * 如果只用来表示时分秒,通常用TIME 来表示。 * 如...

sqlserver查询数据的所有表名和行数

1 //查询所有表明 select name from sysobjects where xtype='u' 2 3 select * fromsys.tables 4 //查询数据库中所有的表名及行数 5 6 SELECTa.name, b.rows 7 8 FROM sysobjects AS a INNER JOIN sysindexes...