中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

php導(dǎo)出CSV抽象類實(shí)例
來源:易賢網(wǎng) 閱讀:952 次 日期:2014-09-29 12:05:13
溫馨提示:易賢網(wǎng)小編為您整理了“php導(dǎo)出CSV抽象類實(shí)例”,方便廣大網(wǎng)友查閱!

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

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

ExportCSV.class.php類文件如下:

?123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 <?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()){ // 對數(shù)組每個元素進(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示例程序如下:

?12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 <?php // ExportCSV abstract class require "ExportCSV.class.php"; // 定義繼承類 class myexport extends ExportCSV{ // 要導(dǎo)出的數(shù)據(jù),實(shí)際情況會從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(); ?>

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:php導(dǎo)出CSV抽象類實(shí)例
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2026上岸·考公考編培訓(xùn)報班

  • 報班類型
  • 姓名
  • 手機(jī)號
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲高清视频的网址| 亚洲伊人一本大道中文字幕| 久久久久**毛片大全| 亚洲精品专区| 亚洲人成网站精品片在线观看| 国产午夜精品全部视频播放| 国产精品久久久久久久久久免费| 欧美日韩精品在线观看| 欧美日韩国产一区二区三区| 欧美另类亚洲| 欧美午夜国产| 国产精品日韩久久久| 国产精品永久免费视频| 国产女优一区| 国产一区二区久久| 伊人成人开心激情综合网| 在线观看视频日韩| 亚洲精品日日夜夜| 中文日韩电影网站| 香蕉久久国产| 久久噜噜亚洲综合| 欧美国产精品劲爆| 国产精品福利片| 国产色产综合产在线视频| 国产一区二区三区av电影| 樱桃视频在线观看一区| 亚洲精品午夜精品| 亚洲欧美日韩久久精品 | 亚洲国产99精品国自产| 一区视频在线看| 亚洲国产影院| 亚洲天堂av图片| 欧美在线视频一区二区三区| 久久中文字幕导航| 欧美日韩免费一区| 国产欧美在线播放| 亚洲高清中文字幕| 亚洲永久精品国产| 久久天天躁狠狠躁夜夜av| 欧美精品www在线观看| 国产精品欧美经典| 亚洲国产精品一区二区www| 亚洲调教视频在线观看| 久久国产日韩| 欧美精品亚洲| 国内自拍一区| 一区二区三区www| 欧美一级在线播放| 欧美精品v日韩精品v国产精品| 欧美性色aⅴ视频一区日韩精品| 国产亚洲激情| 这里只有视频精品| 久久亚洲综合色| 国产精品白丝jk黑袜喷水| 精品成人一区| 欧美一区深夜视频| 国产精品二区在线| 亚洲三级免费电影| 久久久久久久国产| 国产精品毛片a∨一区二区三区| 亚洲第一主播视频| 欧美一区二区三区啪啪| 欧美日韩精品不卡| 亚洲国产天堂久久综合网| 久久精品国产一区二区三区免费看 | 欧美日韩日日骚| 影音先锋久久久| 欧美与黑人午夜性猛交久久久| 欧美精品一区在线发布| 激情综合自拍| 欧美一级视频精品观看| 欧美性片在线观看| 99成人在线| 欧美激情中文字幕一区二区| 激情五月***国产精品| 亚欧成人精品| 国产麻豆日韩| 亚洲欧美日韩在线| 国产精品伦理| 亚洲电影中文字幕| 99在线热播精品免费| 国产性色一区二区| 亚洲夜晚福利在线观看| 欧美激情亚洲另类| 亚洲国产一区二区a毛片| 久久久国产午夜精品| 国产精品视频午夜| 午夜精品久久久久久久99热浪潮| 欧美日韩三级在线| 亚洲美女视频在线免费观看| 欧美承认网站| 亚洲欧洲精品一区二区三区| 蜜桃av噜噜一区| 亚洲国产另类久久精品| 欧美va天堂| 亚洲乱码精品一二三四区日韩在线 | 日韩视频在线一区二区三区| 久久精品理论片| 国产一区二区三区不卡在线观看| 亚欧成人精品| 国产一区二区三区四区老人| 欧美在线高清| 在线成人性视频| 免费成人高清| 日韩写真在线| 国产精品久久久久久久久搜平片 | 日韩网站在线| 欧美日韩喷水| 午夜精品久久久久久99热软件| 国产精品一区亚洲| 久久久久久电影| 亚洲精品少妇网址| 国产精品v亚洲精品v日韩精品| 午夜视频在线观看一区二区| 国产私拍一区| 欧美 亚欧 日韩视频在线| 亚洲看片免费| 国产欧美日韩精品在线| 久久一区二区三区四区五区| 亚洲精品欧洲精品| 国产日韩欧美综合| 猛男gaygay欧美视频| 亚洲视频一二三| 国内精品久久久久国产盗摄免费观看完整版| 久久精品一区二区国产| 亚洲区免费影片| 国产精品永久入口久久久| 久久综合久久久久88| 亚洲毛片在线观看| 国产一区二区三区的电影| 欧美黑人国产人伦爽爽爽| 午夜久久久久久| 亚洲精品国产精品乱码不99| 国产精品区二区三区日本| 另类综合日韩欧美亚洲| 亚洲一区二区三区在线看| 在线免费一区三区| 国产精自产拍久久久久久| 欧美国产日韩一二三区| 久久精精品视频| 亚洲午夜免费福利视频| 亚洲春色另类小说| 国产女主播一区二区| 欧美日韩精品二区| 欧美 亚欧 日韩视频在线| 亚洲伊人观看| 亚洲最黄网站| 91久久视频| 国模精品一区二区三区色天香| 欧美深夜影院| 欧美精品乱码久久久久久按摩| 久久久久国产一区二区| 亚洲免费婷婷| 亚洲午夜精品在线| 日韩午夜av在线| 最新国产成人在线观看| 在线欧美电影| 黄色成人在线网址| 国产一区导航| 国产欧美一区二区精品忘忧草| 欧美吻胸吃奶大尺度电影| 欧美激情综合网| 免费日韩成人| 美女福利精品视频| 久久久久成人精品免费播放动漫| 亚洲欧美精品一区| 亚洲曰本av电影| 亚洲男人影院| 欧美一区免费| 久久国产精品久久精品国产| 亚洲综合精品| 亚洲欧美日韩视频一区| 亚洲一区二区网站| 亚洲欧美中文在线视频| 午夜精品福利视频| 午夜日韩视频| 欧美在线三区| 久久久蜜桃一区二区人| 久久久久久一区| 老司机精品视频网站| 免费看黄裸体一级大秀欧美| 久久尤物电影视频在线观看| 另类专区欧美制服同性| 欧美大片一区二区| 欧美日本三区| 国产精品美女久久久久av超清| 国产精品成av人在线视午夜片| 国产精品激情| 国产手机视频精品| 在线不卡免费欧美| 亚洲精品黄色| 亚洲欧美另类久久久精品2019| 性欧美xxxx视频在线观看| 久久精品视频在线播放| 久久综合九色综合欧美就去吻| 欧美成人性生活| 欧美日韩精品中文字幕| 国产精品你懂得| 狠狠狠色丁香婷婷综合久久五月 | 欧美日韩国产精品一卡|