溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

php導(dǎo)出CSV抽象類的方法

發(fā)布時(shí)間:2021-06-29 14:19:11 來源:億速云 閱讀:141 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“php導(dǎo)出CSV抽象類的方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“php導(dǎo)出CSV抽象類的方法”吧!

本文實(shí)例講述了php導(dǎo)出CSV抽象類及其應(yīng)用,分享給大家供大家參考。具體分析如下:

該php導(dǎo)出CSV抽象類,可根據(jù)總記錄數(shù)與每批次記錄數(shù),計(jì)算總批次,循環(huán)導(dǎo)出。避免內(nèi)存不足的問題。

ExportCSV.class.php類文件如下:

<?php 
/** php Export CSV abstract class,根據(jù)總記錄數(shù)與每批次記錄數(shù),計(jì)算總批次,循環(huán)導(dǎo)出。 
*  Date:  2014-05-16 
*  Author: fdipzone 
*  Ver:  1.0 
* 
*  Func: 
*  public setPageSize   設(shè)置每批次導(dǎo)出的記錄條數(shù) 
*  public setExportName  設(shè)置導(dǎo)出的文件名 
*  public setSeparator   設(shè)置分隔符 
*  public setDelimiter   設(shè)置定界符 
*  public export      執(zhí)行導(dǎo)出 
*  private getPageCount   計(jì)算導(dǎo)出總批次 
*  private setHeader    設(shè)置導(dǎo)出文件header 
*  private formatCSV    將數(shù)據(jù)格式化為csv格式 
*  private escape      轉(zhuǎn)義字符串 
*  abstract getExportTotal 獲取總記錄條數(shù),抽象方法,需繼承類實(shí)現(xiàn) 
*  abstract getExportFields 獲取導(dǎo)出的列名,抽象方法,需繼承類實(shí)現(xiàn) 
*  abstract getExportData  獲取每頁記錄,抽象方法,需繼承類實(shí)現(xiàn) 
*/ 
 
abstract class ExportCSV{ // class start 
 
  // 定義子類必須要實(shí)現(xiàn)的方法 
   
  /** 獲取總記錄條數(shù) 
  * @return int 
  */ 
  abstract protected function getExportTotal(); 
 
  /** 獲取導(dǎo)出的列名 
  * @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;      // 每批次導(dǎo)出的記錄數(shù) 
  protected $exportName = 'export.csv'; // 導(dǎo)出的文件名 
  protected $separator = ',';      // 設(shè)置分隔符 
  protected $delimiter = '"';      // 設(shè)置定界符 
 
 
  /** 設(shè)置每次導(dǎo)出的記錄條數(shù) 
  * @param int $pagesize 每次導(dǎo)出的記錄條數(shù) 
  */ 
  public function setPageSize($pagesize=0){ 
    if(is_numeric($pagesize) && $pagesize>0){ 
      $this->pagesize = $pagesize; 
    } 
  } 
 
  /** 設(shè)置導(dǎo)出的文件名 
  * @param String $filename 導(dǎo)出的文件名 
  */ 
  public function setExportName($filename){ 
    if($filename!=''){ 
      $this->exportName = $filename; 
    } 
  } 
 
  /** 設(shè)置分隔符 
  * @param String $separator 分隔符 
  */ 
  public function setSeparator($separator){ 
    if($separator!=''){ 
      $this->separator = $separator; 
    } 
  } 
 
  /** 設(shè)置定界符 
  * @param String $delimiter 定界符 
  */ 
  public function setDelimiter($delimiter){ 
    if($delimiter!=''){ 
      $this->delimiter = $delimiter; 
    } 
  } 
 
  /** 導(dǎo)出csv */ 
  public function export(){ 
 
    // 獲取總記錄數(shù) 
    $this->total = $this->getExportTotal(); 
 
    // 沒有記錄 
    if(!$this->total){ 
      return false; 
    } 
 
    // 計(jì)算導(dǎo)出總批次 
    $pagecount = $this->getPageCount(); 
 
    // 獲取導(dǎo)出的列名 
    $fields = $this->getExportFields(); 
 
    // 設(shè)置導(dǎo)出文件header 
    $this->setHeader(); 
 
    // 循環(huán)導(dǎo)出 
    for($i=0; $i<$pagecount; $i++){ 
 
      $exportData = ''; 
 
      if($i==0){ // 第一條記錄前先導(dǎo)出列名 
        $exportData .= $this->formatCSV($fields); 
      } 
 
      // 設(shè)置偏移值 
      $offset = $i*$this->pagesize; 
 
      // 獲取每頁數(shù)據(jù) 
      $data = $this->getExportData($offset, $this->pagesize); 
 
      // 將每頁數(shù)據(jù)轉(zhuǎn)換為csv格式 
      if($data){ 
        foreach($data as $row){ 
          $exportData .= $this->formatCSV($row); 
        } 
      } 
 
      // 導(dǎo)出數(shù)據(jù) 
      echo $exportData; 
    } 
  } 
 
  /** 計(jì)算總批次 */ 
  private function getPageCount(){ 
    $pagecount = (int)(($this->total-1)/$this->pagesize)+1; 
    return $pagecount; 
  } 
 
  /** 設(shè)置導(dǎo)出文件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 要轉(zhuǎn)換為csv格式的數(shù)組 
  */ 
  private function formatCSV($data=array()){ 
    // 對(duì)數(shù)組每個(gè)元素進(jìn)行轉(zhuǎn)義 
    $data = array_map(array($this,'escape'), $data); 
    return $this->delimiter.implode($this->delimiter.$this->separator.$this->delimiter, $data).$this->delimiter."\r\n"; 
  } 
 
  /** 轉(zhuǎ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{ 
 
  // 要導(dǎo)出的數(shù)據(jù),實(shí)際情況會(huì)從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','傲雪星楓','男') 
  ); 
 
  /* 返回總導(dǎo)出記錄數(shù) 
  * @return int 
  */ 
  protected function getExportTotal(){ 
    return count($this->data); 
  } 
 
  /** 返回導(dǎo)出的列名 
  * @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); 
  } 
} 
 
// 導(dǎo)出 
$obj = new myexport(); 
$obj->setPageSize(1); 
$obj->setExportName('myexport.csv'); 
$obj->setSeparator(','); 
$obj->setDelimiter('"'); 
$obj->export(); 
?>

到此,相信大家對(duì)“php導(dǎo)出CSV抽象類的方法”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI