亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

thinkPHP導(dǎo)出csv文件及用表格輸出excel的方法

 更新時間:2015年12月30日 11:34:30   作者:nd  
這篇文章主要介紹了thinkPHP導(dǎo)出csv文件及用表格輸出excel的方法,涉及thinkPHP針對表格與Excel文件的操作技巧,需要的朋友可以參考下

本文實例講述了thinkPHP導(dǎo)出csv文件及用表格輸出excel的方法。分享給大家供大家參考,具體如下:

1.thinkphp導(dǎo)出csv文件

導(dǎo)出csv文件可能就那幾行代碼,今天有個問題困擾我好久,就是導(dǎo)出之后出現(xiàn)一些html代碼,這個不應(yīng)該,view里面是空的,controller中最后也沒有$this->display(),最后細心看到think_page_trace這樣的字樣,恍然大悟,是頁面的跟蹤日志,這個默認是會輸出來的。最后在方法后面加了一個exit結(jié)束就好了,下面是代碼:

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 = "關(guān)鍵字,名稱\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>

這樣也可以導(dǎo)出ecxcel文件,截圖如下

依然注意最后一句exit;如果沒有這一句,excel里面會有一些頁面元素。

希望本文所述對大家基于thinkPHP框架的php程序設(shè)計有所幫助。

相關(guān)文章

  • PHP 一個比較完善的簡單文件上傳

    PHP 一個比較完善的簡單文件上傳

    PHP 一個比較完善的簡單文件上傳 轉(zhuǎn)點別人的代碼,留著自己用!
    2010-03-03
  • PHP實現(xiàn)計算器小功能

    PHP實現(xiàn)計算器小功能

    這篇文章主要為大家詳細介紹了PHP實現(xiàn)計算器小功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • thinkPHP3.2簡單實現(xiàn)文件上傳的方法

    thinkPHP3.2簡單實現(xiàn)文件上傳的方法

    這篇文章主要介紹了thinkPHP3.2簡單實現(xiàn)文件上傳的方法,重點介紹了thinkPHP實現(xiàn)文件上傳功能的控制器文件相關(guān)技巧,需要的朋友可以參考下
    2016-05-05
  • Vagrant(WSL)+PHPStorm+Xdebu 斷點調(diào)試環(huán)境搭建

    Vagrant(WSL)+PHPStorm+Xdebu 斷點調(diào)試環(huán)境搭建

    這篇文章主要介紹了Vagrant(WSL)+PHPStorm+Xdebu 斷點調(diào)試環(huán)境搭建,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • PHP常用文件操作函數(shù)和簡單實例分析

    PHP常用文件操作函數(shù)和簡單實例分析

    下面小編就為大家?guī)硪黄狿HP常用文件操作函數(shù)和簡單實例分析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 淺談thinkphp的nginx配置,以及重寫隱藏index.php入口文件方法

    淺談thinkphp的nginx配置,以及重寫隱藏index.php入口文件方法

    今天小編就為大家分享一篇淺談thinkphp的nginx配置,以及重寫隱藏index.php入口文件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • thinkphp中AJAX返回ajaxReturn()方法分析

    thinkphp中AJAX返回ajaxReturn()方法分析

    這篇文章主要介紹了thinkphp中AJAX返回ajaxReturn()方法,結(jié)合實例形式分析了thinkPHP中ajax操作的功能、數(shù)據(jù)返回格式以及ajaxReturn方法的簡單使用技巧,需要的朋友可以參考下
    2016-12-12
  • PHP隨機生成18位不重復(fù)的訂單號代碼實例

    PHP隨機生成18位不重復(fù)的訂單號代碼實例

    這篇文章主要介紹了PHP隨機生成18位不重復(fù)的訂單號代碼實例,代碼很簡單但是很實用,有需要的同學(xué)可以參考下
    2021-03-03
  • PHP dirname(__FILE__)原理及用法解析

    PHP dirname(__FILE__)原理及用法解析

    這篇文章主要介紹了PHP dirname(__FILE__)原理及用法解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-10-10
  • PHP中使用memcache存儲session的三種配置方法

    PHP中使用memcache存儲session的三種配置方法

    下面簡單說下PHP項目分布式部署中,SESSION的同步方案中的一種,使用Memcache來存儲SESSION。并總結(jié)了三種配置方式,需要的朋友可以參考下
    2014-04-04

最新評論