**php 導出CSV抽象類,根據總記錄數與每批次記錄數,計算總批次,循環導出。避免內存不足的問題。**
**ExportCSV.class.php**
~~~
<?php
/**php Export CSV abstract class,根據總記錄數與每批次記錄數,計算總批次,循環導出。
*Date: 2014-05-16
*Author: fdipzone
*Ver: 1.0
*
*Func:
*public setPageSize 設置每批次導出的記錄條數
*public setExportName 設置導出的文件名
*public setSeparator 設置分隔符
*public setDelimiter 設置定界符
*public export 執行導出
*private getPageCount 計算導出總批次
*private setHeader 設置導出文件header
*private formatCSV 將數據格式化為csv格式
*private escape 轉義字符串
*abstract getExportTotal 獲取總記錄條數,抽象方法,需繼承類實現
*abstract getExportFields 獲取導出的列名,抽象方法,需繼承類實現
*abstract getExportData 獲取每頁記錄,抽象方法,需繼承類實現
*/
abstract class ExportCSV{ // class start
// 定義子類必須要實現的方法
/**獲取總記錄條數
* @return int
*/
abstract protected function getExportTotal();
/**獲取導出的列名
* @return Array
*/
abstract protected function getExportFields();
/**獲取每批次數據
* @param int $offset 偏移量
* @param int $limit 獲取的記錄條數
* @return Array
*/
abstract protected function getExportData($offset, $limit);
// 定義類屬性
protected $total = 0; // 總記錄數
protected $pagesize = 500; // 每批次導出的記錄數
protected $exportName = 'export.csv'; // 導出的文件名
protected $separator = ','; // 設置分隔符
protected $delimiter = '"'; // 設置定界符
/**設置每次導出的記錄條數
* @param int $pagesize 每次導出的記錄條數
*/
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(){
// 獲取總記錄數
$this->total = $this->getExportTotal();
// 沒有記錄
if(!$this->total){
return false;
}
// 計算導出總批次
$pagecount = $this->getPageCount();
// 獲取導出的列名
$fields = $this->getExportFields();
// 設置導出文件header
$this->setHeader();
// 循環導出
for($i=0; $i<$pagecount; $i++){
$exportData = '';
if($i==0){ // 第一條記錄前先導出列名
$exportData .= $this->formatCSV($fields);
}
// 設置偏移值
$offset = $i*$this->pagesize;
// 獲取每頁數據
$data = $this->getExportData($offset, $this->pagesize);
// 將每頁數據轉換為csv格式
if($data){
foreach($data as $row){
$exportData .= $this->formatCSV($row);
}
}
// 導出數據
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格式數據
* @param Array $data 要轉換為csv格式的數組
*/
private function formatCSV($data=array()){
// 對數組每個元素進行轉義
$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{
// 要導出的數據,實際情況會從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','傲雪星楓','男')
);
/* 返回總導出記錄數
* @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 獲取的記錄條數
* @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();
?>
~~~
**源碼下載地址:[點擊查看](http://download.csdn.net/detail/fdipzone/7364495)**
- 前言
- php Captcha 驗證碼類
- php 替換敏感字符串
- php返回數據格式化類
- php XML文件解釋類
- php CSS Update Class
- PHPMailer - PHP email transport class
- PHP 遍歷文件夾及文件類及處理類
- 自動登入google play下載app report
- php click captcha 驗證碼類
- php 獲取頁面中的指定內容類
- php 支持斷點續傳的文件下載類
- php 縮略圖生成類,支持imagemagick及gd庫兩種處理
- php 根據url自動生成縮略圖
- php 過濾html標記屬性類
- php HTTP請求類,支持GET,POST,Multipart/form-data
- php Cookies 操作類
- php 密碼生成類
- php main 與 iframe 相互通訊類(同域/跨域)
- php 根據url自動生成縮略圖,并處理高并發問題
- php Timer 頁面運行時間監測類
- php 雙向隊列類
- php 導出CSV抽象類
- php zip文件內容比較類
- php 獲取/設置用戶訪問頁面語言類
- php 獲取Youtube某個User所有Video信息
- php 字符編碼轉換類,支持ANSI、Unicode、Unicode big endian、UTF-8、UTF-8+Bom 互相轉換
- php 版本處理類