tp5mysql到csv_thinkPHP导出csv文件及用表格输出excel的方法

本文介绍了如何使用ThinkPHP框架正确导出CSV文件,避免HTML源码污染,并提供了一种表格输出Excel的方法,确保文件内容纯净。重点在于Controller中添加exit语句以终止输出,以避免页面跟踪日志干扰。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文实例讲述了thinkPHP导出csv文件及用表格输出excel的方法。分享给大家供大家参考,具体如下:

1.thinkphp导出csv文件

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

1.IndexController.class.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

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

7a547ca2afa15241db91b87afc4b26c0.png

2.用表格输出excel

如下代码purchase_prospects.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 = '

emailfirstnamelastname

while($row = mysql_fetch_array($res)){

$out .= '

'.$row['email'].''.$row['firstname'].''.$row['lastname'].'';

}

$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 = '

email

while($row = mysql_fetch_array($res)){

$out .= '

'.$row['email'].'';

}

$short_name .= '_non-purchased and signup';

break;

}

default:

break;

}

$out .= '

';

header("Content-type:application/vnd.ms-excel");

header("Content-Disposition:filename=$short_name.xls");

echo $out;

exit;

}

?>

Purchase Prospects Report

Select Site:

== select site ==

STI

PA

CW

MCC

CB

STIUK

MCCUK

Select Type:

== select type ==

purchased

non-purchased and signup

$(function(){

$("#submit").click(function(){

if('0' == $("#site_id").val() || '0' == $("#customer_type").val()){

alert('please select Site and Site');

return false;

}

})

});

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

392e118e05e562eb7676d410fac79ba7.png

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

希望本文所述对大家基于thinkPHP框架的php程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值