博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php处理Excel
阅读量:5810 次
发布时间:2019-06-18

本文共 3138 字,大约阅读时间需要 10 分钟。

遇到问题

平时在工作中,时常会出现将数据库表导出为Excel或者将Excel导入数据库表的需求。这一需求早早就已经实现过了,为了方便导入导出,我将其封装成了两个方法,作为记录。

代码实现

phpexcel类库的引用

phpexcel拥有强大的Excel处理能力,在上已经拥有数百万次的下载量,不过实话实说,excel的处理速度仍然是非常慢,数据量较大时慎重使用。在上下载或者直接用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 \PHPExcel\PHPExcel();        //设置表格        $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( \PHPExel\Cell::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 = \PHPExcel\IOFactory::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 = \PHPExcel\IOFactory::identify($inputFileName);        $objReader = \PHPExcel\IOFactory::createReader($inputFileType);        $objPHPExcel = $objReader->load($inputFileName);        $objWorksheet = $objPHPExcel->getActiveSheet();        $highestRow = $objWorksheet->getHighestRow();        $highestColumn = $objWorksheet->getHighestColumn();        $highestColumnIndex = \PHPExcel\Cell::columnIndexFromString($highestColumn);//总列数        $row = 1;        $curr = array();        while ($row <= $highestRow) {            for ($col = 0; $col < $highestColumnIndex; $col++) {                $value = str_replace(array("\n\r", "\n", "\r"), "", $objWorksheet->getCellByColumnAndRow($col, $row)->getValue());                $curr[$row][] = $value;            }            $row++;        }        array_shift($curr);//第一行一般是字段名(Excel中列的标题),导入时要移除        return $curr;    }

其他

  • 导出时保存的格式是xlsx,想要改成其他格式需要传入不同的参数。
  • 导入时如果有多个sheet时需要在上次打开时在要导入的sheet页(以保证当前sheet为activeSheet)关闭,或者根据sheet名在程序中选择sheet。

转载地址:http://phjbx.baihongyu.com/

你可能感兴趣的文章
10g手动创建数据库
查看>>
Windwos Server 2008 R2 DHCP服务
查看>>
UVa 11292 勇者斗恶龙(The Dragon of Loowater)
查看>>
白话算法(7) 生成全排列的几种思路(二) 康托展开
查看>>
d3 v4实现饼状图,折线标注
查看>>
微软的云策略
查看>>
Valid Parentheses
查看>>
【ES6】数值的扩展
查看>>
性能测试之稳定性测试
查看>>
ES6的 Iterator 遍历器
查看>>
2019届高二(下)半期考试题(文科)
查看>>
nginx 301跳转到带www域名方法rewrite(转)
查看>>
AIX 配置vncserver
查看>>
windows下Python 3.x图形图像处理库PIL的安装
查看>>
【IL】IL生成exe的方法
查看>>
network
查看>>
SettingsNotePad++
查看>>
centos7安装cacti-1.0
查看>>
3个概念,入门 Vue 组件开发
查看>>
没有JS的前端:体积更小、速度更快!
查看>>