laravel,csv導(dǎo)出

<?php


namespace App\Libs;


class CSVExport
{
    /** @var null 查詢 MYSQL得到的生成器 */
    private $generator = null;
    /** @var array 表頭 */
    private $tableHeader = array();
    /** 表頭中的字段名 @var array */
    private $tableHeaderFiledName = array();
    /** 表頭中的輸出顯示漢字 @var array */
    private $tableHeaderFiledNameDesc = array();
    /** 下載的文件名,不帶后綴 @var string */
    private $fileName = '';
    /** 字段轉(zhuǎn)換的.回調(diào)函數(shù) @var null */
    private $convert = null;
    /** 直接下載@ var bool */
    private $directDownload = true;
    /** 腳本超時時間 @var int */
    private $timeout = 300;

    /**
     * CSVExport constructor.
     *
     * @param          $generator
     * @param array    $tableHeader 表頭,一維數(shù)組['field_name'=>'要展示的文字']
     * @param string   $fileName    下載時的文件名, 不含后綴
     * @param callable $convert     回調(diào)函數(shù), 用來處理某些字段
     */
    public function __construct ($generator, $tableHeader , $fileName = '' , $convert = null)
    {
        $this->generator                = $generator;
        $this->tableHeader              = $tableHeader;
        $this->tableHeaderFiledName     = array_keys($tableHeader);
        $this->tableHeaderFiledNameDesc = array_values($tableHeader);
        $this->fileName                 = $fileName ? $fileName : md5(time());
        $this->convert                  = $convert;
    }

    /**
     * @return float|int
     */
    public function getTimeout ()
    {
        return $this->timeout;
    }

    /**
     * @param float|int $timeout
     */
    public function setTimeout ($timeout)
    {
        $this->timeout = $timeout;
    }

    /**
     * 執(zhí)行查詢導(dǎo)出操作
     */
    function doExport(){
        set_time_limit($this->timeout);//超時限制
        // 向?yàn)g覽器發(fā)送 http 下載頭
        $this->sendHTTPHeader($this->fileName);
        echo $this->tableHeaderDescImplode(); //表頭

        //遍歷生成器, 發(fā)送數(shù)據(jù)
        foreach ($this->generator as $data) {
            $data = get_object_vars($data);
            if ($this->convert){
                $data = call_user_func($this->convert,$data);
            }
            echo $this->dataFieldImplode($data);
        }
    }
    /**
     * 拼接表頭
     * @return string 逗號分割的表頭字符串
     */
    private function tableHeaderDescImplode(){
        $str = implode("\t,", $this->tableHeaderFiledNameDesc);
        return $str.PHP_EOL;
    }
    /**
     * 按照表頭字段,從結(jié)果集取出對應(yīng)的字段,拼接
     * @param array $data 數(shù)據(jù)庫結(jié)果集, 一維數(shù)組
     *
     * @return string 拼接后的字符傳
     */
    private function dataFieldImplode($data){
        $str = '';
        foreach ($this->tableHeaderFiledName as $field){
            $str .= $data[$field]."\t,";
        }
        return rtrim($str,',').PHP_EOL;
    }
    /**
     * 發(fā)送http下載header
     *
     * @param $fileName
     */
    private function sendHTTPHeader($fileName){
        header("Cache-control: private");
        header("Pragma: public");
        header('Content-type: application/x-csv');
        header("Content-Disposition:attachment;filename=" . $fileName. ".csv");
    }
}

調(diào)用

$query = "select * from skyshop_member limit 10000 ";
        $generator = DB::connection()->cursor($query);

        $tableHeader = [
            'id'=>'序號',
            'full_name'=>'全名'
        ];
        $fileName = 'csv導(dǎo)出測試';
        $callable = function($data){
            if($data['id'] == 1){
                $data['id'] = 'yi';
            }
            return $data;
        };
        $CSVExport = new CSVExport($generator, $tableHeader, $fileName,$callable);
        $CSVExport->doExport();
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末寸士,一起剝皮案震驚了整個濱河市互例,隨后出現(xiàn)的幾起案子惕艳,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,406評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件白粉,死亡現(xiàn)場離奇詭異讯壶,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)状婶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評論 3 398
  • 文/潘曉璐 我一進(jìn)店門意敛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人膛虫,你說我怎么就攤上這事草姻。” “怎么了稍刀?”我有些...
    開封第一講書人閱讀 167,815評論 0 360
  • 文/不壞的土叔 我叫張陵撩独,是天一觀的道長敞曹。 經(jīng)常有香客問我,道長综膀,這世上最難降的妖魔是什么澳迫? 我笑而不...
    開封第一講書人閱讀 59,537評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮剧劝,結(jié)果婚禮上橄登,老公的妹妹穿的比我還像新娘。我一直安慰自己讥此,他們只是感情好拢锹,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,536評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著萄喳,像睡著了一般卒稳。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上他巨,一...
    開封第一講書人閱讀 52,184評論 1 308
  • 那天充坑,我揣著相機(jī)與錄音,去河邊找鬼闻蛀。 笑死匪傍,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的觉痛。 我是一名探鬼主播役衡,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼薪棒!你這毒婦竟也來了手蝎?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,668評論 0 276
  • 序言:老撾萬榮一對情侶失蹤俐芯,失蹤者是張志新(化名)和其女友劉穎棵介,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吧史,經(jīng)...
    沈念sama閱讀 46,212評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡邮辽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,299評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了贸营。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吨述。...
    茶點(diǎn)故事閱讀 40,438評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖钞脂,靈堂內(nèi)的尸體忽然破棺而出揣云,到底是詐尸還是另有隱情,我是刑警寧澤冰啃,帶...
    沈念sama閱讀 36,128評論 5 349
  • 正文 年R本政府宣布邓夕,位于F島的核電站刘莹,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏焚刚。R本人自食惡果不足惜点弯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,807評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望汪榔。 院中可真熱鬧蒲拉,春花似錦肃拜、人聲如沸痴腌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽士聪。三九已至,卻和暖如春猛蔽,著一層夾襖步出監(jiān)牢的瞬間剥悟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評論 1 272
  • 我被黑心中介騙來泰國打工曼库, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留区岗,地道東北人。 一個月前我還...
    沈念sama閱讀 48,827評論 3 376
  • 正文 我出身青樓毁枯,卻偏偏與公主長得像慈缔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子种玛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,446評論 2 359

推薦閱讀更多精彩內(nèi)容