php導出CSV抽象類實例
更新時間:2014年09月24日 15:03:16 投稿:shichen2014
這篇文章主要介紹了php導出CSV抽象類及其用法示例,可實現(xiàn)循環(huán)導出功能,從而避免內(nèi)存不足的問題,需要的朋友可以參考下
本文實例講述了php導出CSV抽象類及其應用,分享給大家供大家參考。具體分析如下:
該php導出CSV抽象類,可根據(jù)總記錄數(shù)與每批次記錄數(shù),計算總批次,循環(huán)導出。避免內(nèi)存不足的問題。
ExportCSV.class.php類文件如下:
<?php /** php Export CSV abstract class,根據(jù)總記錄數(shù)與每批次記錄數(shù),計算總批次,循環(huán)導出。 * Date: 2014-05-16 * Author: fdipzone * Ver: 1.0 * * Func: * public setPageSize 設置每批次導出的記錄條數(shù) * public setExportName 設置導出的文件名 * public setSeparator 設置分隔符 * public setDelimiter 設置定界符 * public export 執(zhí)行導出 * private getPageCount 計算導出總批次 * private setHeader 設置導出文件header * private formatCSV 將數(shù)據(jù)格式化為csv格式 * private escape 轉義字符串 * abstract getExportTotal 獲取總記錄條數(shù),抽象方法,需繼承類實現(xiàn) * abstract getExportFields 獲取導出的列名,抽象方法,需繼承類實現(xiàn) * abstract getExportData 獲取每頁記錄,抽象方法,需繼承類實現(xiàn) */ abstract class ExportCSV{ // class start // 定義子類必須要實現(xiàn)的方法 /** 獲取總記錄條數(shù) * @return int */ abstract protected function getExportTotal(); /** 獲取導出的列名 * @return Array */ abstract protected function getExportFields(); /** 獲取每批次數(shù)據(jù) * @param int $offset 偏移量 * @param int $limit 獲取的記錄條數(shù) * @return Array */ abstract protected function getExportData($offset, $limit); // 定義類屬性 protected $total = 0; // 總記錄數(shù) protected $pagesize = 500; // 每批次導出的記錄數(shù) protected $exportName = 'export.csv'; // 導出的文件名 protected $separator = ','; // 設置分隔符 protected $delimiter = '"'; // 設置定界符 /** 設置每次導出的記錄條數(shù) * @param int $pagesize 每次導出的記錄條數(shù) */ public function setPageSize($pagesize=0){ if(is_numeric($pagesize) && $pagesize>0){ $this->pagesize = $pagesize; } } /** 設置導出的文件名 * @param String $filename 導出的文件名 */ public function setExportName($filename){ if($filename!=''){ $this->exportName = $filename; } } /** 設置分隔符 * @param String $separator 分隔符 */ public function setSeparator($separator){ if($separator!=''){ $this->separator = $separator; } } /** 設置定界符 * @param String $delimiter 定界符 */ public function setDelimiter($delimiter){ if($delimiter!=''){ $this->delimiter = $delimiter; } } /** 導出csv */ public function export(){ // 獲取總記錄數(shù) $this->total = $this->getExportTotal(); // 沒有記錄 if(!$this->total){ return false; } // 計算導出總批次 $pagecount = $this->getPageCount(); // 獲取導出的列名 $fields = $this->getExportFields(); // 設置導出文件header $this->setHeader(); // 循環(huán)導出 for($i=0; $i<$pagecount; $i++){ $exportData = ''; if($i==0){ // 第一條記錄前先導出列名 $exportData .= $this->formatCSV($fields); } // 設置偏移值 $offset = $i*$this->pagesize; // 獲取每頁數(shù)據(jù) $data = $this->getExportData($offset, $this->pagesize); // 將每頁數(shù)據(jù)轉換為csv格式 if($data){ foreach($data as $row){ $exportData .= $this->formatCSV($row); } } // 導出數(shù)據(jù) echo $exportData; } } /** 計算總批次 */ private function getPageCount(){ $pagecount = (int)(($this->total-1)/$this->pagesize)+1; return $pagecount; } /** 設置導出文件header */ private function setHeader(){ header('content-type:application/x-msexcel'); $ua = $_SERVER['HTTP_USER_AGENT']; if(preg_match("/MSIE/", $ua)){ header('content-disposition:attachment; filename="'.rawurlencode($this->exportName).'"'); }elseif(preg_match("/Firefox/", $ua)){ header("content-disposition:attachment; filename*=\"utf8''".$this->exportName.'"'); }else{ header('content-disposition:attachment; filename="'.$this->exportName.'"'); } ob_end_flush(); ob_implicit_flush(true); } /** 格式化為csv格式數(shù)據(jù) * @param Array $data 要轉換為csv格式的數(shù)組 */ private function formatCSV($data=array()){ // 對數(shù)組每個元素進行轉義 $data = array_map(array($this,'escape'), $data); return $this->delimiter.implode($this->delimiter.$this->separator.$this->delimiter, $data).$this->delimiter."\r\n"; } /** 轉義字符串 * @param String $str * @return String */ private function escape($str){ return str_replace($this->delimiter, $this->delimiter.$this->delimiter, $str); } } // class end ?>
demo示例程序如下:
<?php // ExportCSV abstract class require "ExportCSV.class.php"; // 定義繼承類 class myexport extends ExportCSV{ // 要導出的數(shù)據(jù),實際情況會從db讀取 protected $data = array( array('1','傲雪星楓"','男'), array('2','傲雪星楓","','男'), array('3','傲雪星楓","','男'), array('4',"傲雪星楓\"\"\r\n換行",'男'), array('5','傲雪星楓,,','男'), array('6','傲雪星楓"','男'), array('7','傲雪星楓','男'), array('8','傲雪星楓','男'), array('9','傲雪星楓','男'), array('10','傲雪星楓','男') ); /* 返回總導出記錄數(shù) * @return int */ protected function getExportTotal(){ return count($this->data); } /** 返回導出的列名 * @return Array */ protected function getExportFields(){ $title = array('id','name','gender'); return $title; } /* 返回每批次的記錄 * @param int $offset 偏移量 * @param int $limit 獲取的記錄條數(shù) * @return Array */ protected function getExportData($offset, $limit){ return array_slice($this->data, $offset, $limit); } } // 導出 $obj = new myexport(); $obj->setPageSize(1); $obj->setExportName('myexport.csv'); $obj->setSeparator(','); $obj->setDelimiter('"'); $obj->export(); ?>
完整實例代碼點擊此處本站下載。
希望本文所述對大家的PHP程序設計有所幫助。
您可能感興趣的文章:
- thinkPHP導出csv文件及用表格輸出excel的方法
- 基于php導出到Excel或CSV的詳解(附utf8、gbk 編碼轉換)
- PHP導出MySQL數(shù)據(jù)到Excel文件(fputcsv)
- 詳解PHP導入導出CSV文件
- php導出csv數(shù)據(jù)在瀏覽器中輸出提供下載或保存到文件的示例
- php導出csv格式數(shù)據(jù)并將數(shù)字轉換成文本的思路以及代碼分享
- PHP 導出數(shù)據(jù)到淘寶助手CSV的方法分享
- PHP實現(xiàn)CSV文件的導入和導出類
- PHP 實現(xiàn)從數(shù)據(jù)庫導出到.csv文件方法
- php使用指定編碼導出mysql數(shù)據(jù)到csv文件的方法
- 原生PHP實現(xiàn)導出csv格式Excel文件的方法示例【附源碼下載】
相關文章
php ignore_user_abort與register_shutdown_function 使用方法
php ignore_user_abort與register_shutdown_function 使用方法小結。2009-06-06學習php設計模式 php實現(xiàn)策略模式(strategy)
這篇文章主要介紹了php設計模式中的適配器模式,使用php實現(xiàn)適配器模式,感興趣的小伙伴們可以參考一下2015-12-12獲取php頁面執(zhí)行時間,數(shù)據(jù)庫讀寫次數(shù),函數(shù)調用次數(shù)等(THINKphp)
這篇文章主要是thinkphp獲取php頁面執(zhí)行時間,數(shù)據(jù)庫讀寫次數(shù),函數(shù)調用次數(shù)等,需要的朋友可以參考下2013-06-06