国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

php處理Excel

gitmilk / 2266人閱讀

摘要:導出成為在絕大多數情況下,導出其實就是將二維數組轉化為表格。要保存的的名字轉換為表格的二維數組設置表格填充數據設置表格并輸出導入同理,導入其實就是將的數據轉化成為二維數組,這就要求必須符合格式。

遇到問題

平時在工作中,時常會出現將數據庫表導出為Excel或者將Excel導入數據庫表的需求。這一需求早早就已經實現過了,為了方便導入導出,我將其封裝成了兩個方法,作為記錄。

代碼實現 phpexcel類庫的引用

phpexcel擁有強大的Excel處理能力,在packagist上已經擁有數百萬次的下載量,不過實話實說,excel的處理速度仍然是非常慢,數據量較大時慎重使用。在packagist上下載或者直接用composer require phpoffice/phpexcel之后,便可以使用phpexcel了。

導出成為Excel

在絕大多數情況下,導出excel其實就是將二維數組轉化為表格。

    /**
     * @param $name string 要保存的Excel的名字
     * @param $ret_data 轉換為表格的二維數組
     * @throws PHPExcel_Exception
     * @throws PHPExcel_Reader_Exception
     */
    function exportExcel($name, $ret_data){
        $objPHPExcel = new PHPExcelPHPExcel();
        //設置表格
        $objPHPExcel->getProperties()->setCreator($name)
                ->setLastModifiedBy($name)
                ->setTitle("Office 2007 XLSX Test Document")
                ->setSubject("Office 2007 XLSX Test Document")
                ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
                ->setKeywords("office 2007 openxml php")
                ->setCategory("Test result file");
        //填充數據
        foreach ($ret_data as $key => $row) {
            $num = $key + 1;
            //$row = array_values($row);
            $i=0;
            foreach ($row as $key2 => $value2) {
                $objPHPExcel->setActiveSheetIndex(0)->setCellValue( PHPExelCell::stringFromColumnIndex($i). ($num), $value2);
                $i++;
            }
        }
        //設置表格并輸出
        $objPHPExcel->getActiveSheet()->setTitle($name);
        header("Content-Type: application/vnd.ms-excel");
        header("Content-Disposition: attachment;filename={$name}.xls");
        header("Cache-Control: max-age=0");
        header("Cache-Control: max-age=1");
        header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
        header("Cache-Control: cache, must-revalidate");
        header("Pragma: public"); // HTTP/1.0
        $objWriter = PHPExcelIOFactory::createWriter($objPHPExcel, "Excel5");
        $objWriter->save("php://output");
        exit;
    }
導入Excel

同理,導入Excel其實就是將Excel的數據轉化成為二維數組,這就要求Excel必須符合格式。

 function getRows($inputFileName)
    {
        if (!file_exists($inputFileName)) {
            throw new Exception("File not existed");
        }
        $inputFileType = PHPExcelIOFactory::identify($inputFileName);
        $objReader = PHPExcelIOFactory::createReader($inputFileType);
        $objPHPExcel = $objReader->load($inputFileName);
        $objWorksheet = $objPHPExcel->getActiveSheet();
        $highestRow = $objWorksheet->getHighestRow();
        $highestColumn = $objWorksheet->getHighestColumn();
        $highestColumnIndex = PHPExcelCell::columnIndexFromString($highestColumn);//總列數
        $row = 1;
        $curr = array();
        while ($row <= $highestRow) {
            for ($col = 0; $col < $highestColumnIndex; $col++) {
                $value = str_replace(array("

", "
", "
"), "", $objWorksheet->getCellByColumnAndRow($col, $row)->getValue());
                $curr[$row][] = $value;
            }
            $row++;
        }
        array_shift($curr);//第一行一般是字段名(Excel中列的標題),導入時要移除
        return $curr;
    }
其他

導出時保存的格式是xlsx,想要改成其他格式需要傳入不同的參數。

導入時如果有多個sheet時需要在上次打開時在要導入的sheet頁(以保證當前sheet為activeSheet)關閉,或者根據sheet名在程序中選擇sheet。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/21708.html

相關文章

  • php 導出 excel

    關于 PHP 導出 excel csv 常用的有 PHPexcel ,本文整理了一些其他方案。 高性能 Excel 擴展 sudo apt-get install -y zlib1g-dev git clone https://github.com/jmcnamara/libxlsxwriter.git cd libxlsxwriter make && sudo make install // ...

    付永剛 評論0 收藏0
  • 如何在 Laravel 項目中處理 Excel 文件

    摘要:本文經授權轉自社區說明是一款強大的文件處理擴展包能夠快速完成文件的的導出解析等功能本項目由團隊成員整理發布首發地為社區文章的項目截圖運行代碼請見請參照此文檔運行文章概覽安裝基礎用法更多功能接下來是詳細解說安裝使用安裝該擴展包安裝完成后, 本文經授權轉自 PHPHub 社區 說明 maatwebsite/excel 是一款強大的 Excel 文件處理擴展包, 能夠快速完成 Excel 文...

    chadLi 評論0 收藏0
  • ThinkPHPPHPExcle導出Excel文件

    摘要:本篇文章主要講述,如何在中使用中導出文件,是博主在實踐了好多篇別人的帖子之后,總結歸納出來的文章,親測可用。我的博客歡迎騷擾原文地址用導出文件。將文件,重命名成。文章結束,歡迎轉載。 本篇文章主要講述,如何在thinkPHP中使用PHPExcel中導出Excel文件,是博主在實踐了好多篇別人的帖子之后,總結歸納出來的文章,親測可用。thinkPHP版本是3.2。 我的博客:Mine-...

    rollback 評論0 收藏0
  • phpExcel實現Excel數據的導入導出(全步驟詳細解析)

    摘要:上傳添加需下載類文件,引入到項目類庫里接收前臺文件,接收前臺文件重設置文件名設置移動路徑表用函數方法返回數組創建一個讀取數據,可用于入庫引用類靜態類設置為代表支持或以下版本,代表版開始讀取上傳到服務器中的文件,返回一個二維數組 1.上傳添加excel (需下載PHPExcel類文件,引入到項目類庫里) //接收前臺文件, public function addExcel() ...

    zengdongbao 評論0 收藏0
  • PHP讀取超大的excel文件數據的方案

    摘要:場景和痛點說明今天因為一個老同學找我,說自己公司的物流業務都是現在用處理,按月因為數據量大,一個差不多有百萬數據,文件有接近,打開和搜索就相當的慢聯想到場景要導入數據,可能數據量很大,這里利用常用的一些方法比如會常有時間和內存限制問題下面我 場景和痛點 說明 今天因為一個老同學找我,說自己公司的物流業務都是現在用excel處理,按月因為數據量大,一個excel差不多有百萬數據,文件有接...

    dkzwm 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<