php导出CSV抽象类实例

前端之家收集整理的这篇文章主要介绍了php导出CSV抽象类实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了PHP导出CSV抽象类及其应用,分享给大家供大家参考。具体分析如下:

PHP导出CSV抽象类,可根据总记录数与每批次记录数,计算总批次,循环导出。避免内存不足的问题。

ExportCSV.class.PHP文件如下:

PHP;"> 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(){

  1. // <a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>总记录数
  2. $this->total = $this->getExportTotal();
  3. // 没有记录
  4. if(!$this->total){
  5. return false;
  6. }
  7. // 计算导出总批次
  8. $pagecount = $this->getPageCount();
  9. // <a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>导出的列名
  10. $fields = $this->getExportFields();
  11. // 设置导出<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>header
  12. $this->setHeader();
  13. // 循环导出
  14. for($i=0; $i<$pagecount; $i++){
  15. $exportData = '';
  16. if($i==0){ // 第一条记录前先导出列名
  17. $exportData .= $this->formatCSV($fields);
  18. }
  19. // 设置偏移值
  20. $offset = $i*$this->pagesize;
  21. // <a href="/tag/huoqu/" target="_blank" class="keywords">获取</a>每页数据
  22. $data = $this->getExportData($offset,$this->pagesize);
  23. // 将每页数据转换为csv格式
  24. if($data){
  25. foreach($data as $row){
  26. $exportData .= $this->formatCSV($row);
  27. }
  28. }
  29. // 导出数据
  30. echo $exportData;
  31. }

}

/* 计算总批次 /
private function getPageCount(){
$pagecount = (int)(($this->total-1)/$this->pagesize)+1;
return $pagecount;
}

/* 设置导出文件header /
private function setHeader(){
header('content-type:application/x-msexcel');

  1. $ua = $_SERVER['HTTP_USER_AGENT'];
  2. if(preg_match("/MSIE/",$ua)){
  3. header('content-disposition:attachment; filename="'.rawurlencode($this->exportName).'"');
  4. }elseif(preg_match("/Firefox/",$ua)){
  5. header("content-disposition:attachment; filename*=\"utf8''".$this->exportName.'"');
  6. }else{
  7. header('content-disposition:attachment; filename="'.$this->exportName.'"');
  8. }
  9. ob_end_flush();
  10. 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();
?>

完整实例代码点击此处

希望本文所述对大家的PHP程序设计有所帮助。

猜你在找的PHP相关文章