PHP使用PHPExcel导出,导入数据总结

导出excel:

        header("Content-type: text/html; charset=utf-8");
        include_once dirname(dirname(__FILE__)).'/Classes/PHPExcel.php';
        $objPHPExcel = new PHPExcel();
        $objPHPExcel->getProperties()->setCreator("Maarten Balliauw")
            ->setLastModifiedBy("Maarten Balliauw")
            ->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");
        
        //设置标题
        $objPHPExcel->getActiveSheet()->setTitle($filename);

        //设置表头
        $key1 = 1;
        $objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue('A'.$key1, 'ID')
            ->setCellValue('B'.$key1, '关键词')
            ->setCellValue('C'.$key1, '歌曲HASH')
            ->setCellValue('D'.$key1, '歌曲名')
            ->setCellValue('E'.$key1, '排序')
            ->setCellValue('F'.$key1, '开始日期')
            ->setCellValue('G'.$key1, '结束日期')
            ->setCellValue('H'.$key1, '操作人');

        //设置样式:
        $objPHPExcel->getActiveSheet()->getStyle('A1:H1')->getFont()->setBold(true); //多个单元格
        // $objPHPExcel->getActiveSheet()->getStyle('A1:H1')->getFont()->getColor()->setARGB('FFFF0000'); //设置颜色
        // $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setBold(true); //单个单元格
        $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setAutoSize(true);  //列宽必须单个设置
        $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setAutoSize(true);
        $objPHPExcel->getActiveSheet()->getColumnDimension('D')->setAutoSize(true);
        $objPHPExcel->getActiveSheet()->getColumnDimension('F')->setAutoSize(true);
        $objPHPExcel->getActiveSheet()->getColumnDimension('G')->setAutoSize(true);

        //写入内容
        foreach($datalist as $key =>$value){
            $key1=$key+2;
            $objPHPExcel->setActiveSheetIndex(0)
                ->setCellValue('A'.$key1, $value['id'])
                ->setCellValue('B'.$key1, $value['keyword'])
                ->setCellValue('C'.$key1, $value['hash'])
                ->setCellValue('D'.$key1, $value['filename'])
                ->setCellValue('E'.$key1, $value['weight'])
                ->setCellValue('F'.$key1, $value['startdate'])
                ->setCellValue('G'.$key1, $value['enddate'])
                ->setCellValue('H'.$key1, $value['editor']);
        }
        // $objPHPExcel->setActiveSheetIndex(0);

        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="'. $filename .'.xls"');
        header('Cache-Control: max-age=0');

        $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
        $objWriter->save('php://output');
        exit;

从excel导入:

        header("Content-type: text/html; charset=utf-8");
        $addFile=$_FILES['excel'];
        $excelFileName =$addFile['tmp_name'];
        $location = KG_DOMAIN . '/diysort/index';
        if ($addFile['type'] != 'application/vnd.ms-excel' && $addFile['type'] != 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {
            echo '<script type="text/javascript">alert("上传格式错误");window.location.href="' . $location .'";</script>';
            //header("Location: " . KG_DOMAIN . '/diysort/index');
            exit;
        }
        include_once dirname(dirname(__FILE__)).'/Classes/PHPExcel/IOFactory.php';
    
        $objPHPExcel = PHPExcel_IOFactory::load($excelFileName);
        $objWorksheet = $objPHPExcel->getSheet(0);
        $highestRow    = $objWorksheet->getHighestRow();          // 取得总行数
        $highestColumn = $objWorksheet->getHighestColumn();    // 取得总列数

        $highestColumnIndex = PHPExcel_Cell::columnIndexFromString ( $highestColumn );  
        $excelData = array ();  
        for($row = 1; $row <= $highestRow; $row++) {  
            for($col = 0; $col < $highestColumnIndex; $col++) {  
                $excelData[$row-1][] = $objWorksheet->getCellByColumnAndRow( $col, $row )->getValue();  
            }  
        }  
        //数据入库
        $diysortmodule = new DiysortModule();
        $rowins = 0;
        foreach ($excelData as $key => $value) {
            if (empty($value) || trim($value[0]) == '关键词' || trim($value[0] == 'ID')) {
                continue;
            }
            $keyword = trim(addslashes($value[0]));
            $hash = trim(addslashes($value[1]));
            $filename = trim(addslashes($value[2]));
            $weight = intval($value[3]);
            $startdate = trim(addslashes($value[4]));
            $enddate = trim(addslashes($value[5]));
            $adddate = date('Y-m-d H:i:s',time());
            $input_data = array(
                'keyword'    => $keyword,
                'startdate'  => $startdate,
                'enddate'    => $enddate,
                'hash'       => $hash,
                'filename'   => $filename,
                'weight'     => $weight,
                'adddate'    => $adddate,
                'editor'     => $this->editor, 
            );
            if (!empty($hash) && !empty($filename) && is_numeric($weight)) {
                $newid = $diysortmodule->addData($input_data);
                if ($newid > 0) {
                    $rowins ++;
                }
            }
        }
        echo '<script type="text/javascript">alert("共上传成功'. $rowins.' 条记录");window.location.href="' . $location .'";</script>';
        exit;



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用Laravel框架实现PHPExcel导入导出功能非常简单。首先,我们需要安装PHPExcel库。可以通过Composer来安装,只需在终端中运行以下命令: ``` composer require phpoffice/phpexcel ``` 安装完之后,在Laravel的控制器中,我们可以使用PHPExcel的相关类来实现导入导出功能。 要导出Excel文件,我们可以先创建一个PHPExcel对象,并设置一些基本的属性,例如文件名、作者等。然后,我们可以创建一个工作表,并设置一些表头信息。接下来,我们可以遍历需要导出数据,将数据逐行写入工作表中。最后,我们可以使用PHPExcelWriter将工作表保存为Excel文件。下面是一个示例代码: ```php use PHPExcel; use PHPExcel_IOFactory; class ExportController extends Controller { public function exportData() { $objPHPExcel = new PHPExcel(); // 设置文件属性 $objPHPExcel->getProperties() ->setCreator("Your Name") ->setLastModifiedBy("Your Name") ->setTitle("Export Data") ->setSubject("Export Data") ->setDescription("Export Data"); $objPHPExcel->setActiveSheetIndex(0); $sheet = $objPHPExcel->getActiveSheet(); // 设置表头信息 $sheet->setCellValue('A1', 'Column 1') ->setCellValue('B1', 'Column 2') ->setCellValue('C1', 'Column 3'); // 导出数据 $data = [ ['Data 1', 'Data 2', 'Data 3'], ['Data 4', 'Data 5', 'Data 6'], ]; foreach ($data as $key => $value) { $row = $key + 2; $sheet->setCellValue('A' . $row, $value[0]) ->setCellValue('B' . $row, $value[1]) ->setCellValue('C' . $row, $value[2]); } // 导出Excel $objPHPExcel->getActiveSheet()->setTitle('Sheet 1'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); $objWriter->save('export.xlsx'); } } ``` 要导入Excel文件,我们可以先创建一个PHPExcel对象,并使用`load`方法加载Excel文件。然后,我们可以通过`getActiveSheet`方法获取工作表,并使用`getCell`方法获取单元格的值。接下来,我们可以遍历工作表的行和列,将数据存储到数组中。最后,我们可以对获取到的数据进行相关的处理。下面是一个示例代码: ```php use PHPExcel; use PHPExcel_IOFactory; class ImportController extends Controller { public function importData() { $objPHPExcel = PHPExcel_IOFactory::load('import.xlsx'); $sheet = $objPHPExcel->getActiveSheet(); $data = []; foreach ($sheet->getRowIterator() as $row) { $rowData = []; foreach ($row->getCellIterator() as $cell) { $rowData[] = $cell->getValue(); } $data[] = $rowData; } // 对导入数据进行处理 // ... return $data; } } ``` 通过以上的代码,我们就可以轻松地在Laravel框架中实现PHPExcel导入导出功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值