phpexcel的读取和导出

备注:php页面读取导出Excel时,需要设置:public $enableCsrfValidation = false;

一:读取Excel 

  public function actionImport()
    {
        //上传的文件
        $filename = $_FILES['fileExcel']['tmp_name'];
        $objPHPExcel = \PHPExcel_IOFactory::load($filename);
        $activeSheet = $objPHPExcel->getActiveSheet();
        // 循环取得数据
        foreach ($activeSheet->getRowIterator(2) as $row) {

            // 遍历行,$activeSheet->getRowIterator(2) ,从第二行开始的所有有数据的行
            $row_Index = $row->getRowIndex();
            // 取行$row_Index列1的值
            $scale_premium = $activeSheet->getCellByColumnAndRow(1,
                $row_Index)->getValue();
            }
        }

    }

二、导出   

public function actionExport()
    {
        //设置样式
        $styleThinBlackBorderOutline = array(
            'borders' => array (
                'outline' => array (
                    'style' => \PHPExcel_Style_Border::BORDER_THIN,  //设置border样式
                    'color' => array ('argb' => 'FF000000'),     //设置border颜色
                ),
            ),
        );
        $styleArrayTitle = array(
            'font' => array(
                'bold' => true,
                'size'=>12,
                'color'=>array(
                    'argb' => '00000000',
                ),
            ),
            'alignment' => array(
                'horizontal' => \PHPExcel_Style_Alignment::HORIZONTAL_CENTER,
            ),
            'borders' => array (
                'outline' => array (
                    'style' => \PHPExcel_Style_Border::BORDER_THIN,  //设置border样式
                    'color' => array ('argb' => 'FF000000'),     //设置border颜色
                ),
            ),
            'fill' => array(
                'type' => \PHPExcel_Style_Fill::FILL_SOLID,
                'rotation' => 90,
                'startcolor' => array(
                    'argb' => '00b0f0',
                ),
            ),


        );
        $objPHPExcel = new \PHPExcel();
        //设置当前的sheet
        $objPHPExcel->setActiveSheetIndex(0);
        $objPHPExcel->getActiveSheet()->setTitle(iconv('utf-8', 'utf-8', '写入例子'));
        //设置Excel的列宽
        $objPHPExcel->getActiveSheet()->getDefaultColumnDimension()->setWidth(40);
        //设置Excel行高
        $objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight(20);

        //Add some data

        //设置A1单元的值,类型为String
      $objPHPExcel->getActiveSheet()->setCellValueExplicit('A1', '123',\PHPExcel_Cell_DataType::TYPE_STRING);

      //设置A1单元格的Style
      $objPHPExcel->getActiveSheet()->getStyle('A1')->applyFromArray($styleThinBlackBorderOutline);        
        //页面导出
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        //设置下载的文件名称
        header('Content-Disposition: attachment;filename=' . urlencode('写入例子') . '.xlsx');
        header('Cache-Control: max-age=0');
        // If you're serving to IE 9, then the following may be needed
        header('Cache-Control: max-age=1');
        // If you're serving to IE over SSL, then the following may be needed
        header ('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); // Date in the past
        header ('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT'); // always modified
        header ('Cache-Control: cache, must-revalidate'); // HTTP/1.1
        header ('Pragma: public'); // HTTP/1.0
        $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
        $objWriter->save('php://output');
        exit;
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值