版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/antch620/article/details/79897966
备注: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', '写入例子'));
$objPHPExcel->getActiveSheet()->getDefaultColumnDimension()->setWidth(40);//设置Excel的列宽
$objPHPExcel->getActiveSheet()->getDefaultRowDimension()->setRowHeight(20);//设置Excel行高
//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;
}