phpExcel导入 导出类封装(支持合并单元格)
class ExcelIndex
{
private $excel= null;
private $cellArr= [];
function __construct()
{
// require __DIR__ . "./Classes/PHPExcel.php"; 引入phpexcel 如果用了命名空间就不需要单独引入
$this->excel= new \PHPExcel();
$this->cellArr= ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ'];
}
/**
* @param $data array (必须)数据(二维数组)【只能存在要导出的数据】
* @param $title array (必须)列标中文 ['标题1', '标题1', '标题1', '标题1', '标题1', '标题1']
* @param $filename string (必须)文件名称
* @param $cellNames array (必须)列标英文 ['A', 'B', 'C', 'D', 'E', 'F']
* @param $arr_hb array (可选)是否合并单元格 参数:['A' => 'order_sn', 'B' => 'order_sn']
* @throws \PHPExcel_Exception
*/
public function Export($data, $title, $filename, $cellNames, $arr_hb=[])
{
$cellName= [];
foreach ($cellNames as $key=> $val) {
foreach ($this->cellArras $k=> $v) {
$cellName[]= $val. $v;
}
}
$cellName= array_merge($this->cellArr, $cellName);
/* 设置宽度 */
// $this->excel->getActiveSheet()->getColumnDimension()->setAutoSize(true);
$this->excel->getActiveSheet(0)->mergeCells('A1:AC1'); //合并单元格
$this->excel->getactivesheet()->setCellValue('A1', $filename); //设置标题
//设置SHEET
$this->excel->setactivesheetindex(0);
$this->excel->getActiveSheet()->setTitle('sheet1');
$_row= 2; //设置纵向单元格标识
foreach ($title as $k=> $v) {
$this->excel->getactivesheet()->setCellValue($cellName[$k]. $_row, $v);
}
$i= 1;
foreach ($data AS $_v) {
$j= 0;
foreach ($_vAS $_cell) {
if ($cellName[$j]== 'A' || $cellName[$j]== 'F' || $cellName[$j]== 'L') {//科学转换
$this->excel->getActiveSheet()->setCellValue($cellName[$j]. ($i+ $_row), "\t" . $_cell. "\t");
}else {
$this->excel->getActiveSheet()->setCellValue($cellName[$j]. ($i+ $_row), $_cell);
}
$j++;
}
$i++;
}
//是否合并单元格
if (!empty($arr_hb)&& !empty($arr)) {
foreach ($arr_hb as $k1=> $v1) {
$lert= $this->_remerge($arr, $k1, $v1);
foreach ($lertas $aa) {
$this->excel->getActiveSheet()->mergeCells($aa);
}
}
}
//输出到浏览器
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header('Content-Disposition:attachment;filename="' . $filename . '.xlsx"');
header("Content-Transfer-Encoding:binary");
$objWriter= \PHPExcel_IOFactory::createWriter($this->excel, 'Excel5');
$objWriter->save('php://output');
}
/**
* @param string $filename 要导入的文件
* @param int $start_get 从那一行开始读取
* @param array $hang_tit 头部
* @return array|string
* @throws \PHPExcel_Exception
* @throws \PHPExcel_Reader_Exception
*/
public function Import($file,$start_get=3,$hang_tit=[])
{
if (!file_exists($file)) {
return '文件不存在';
}
$objPHPExcel= \PHPExcel_IOFactory::load($file); //自动文件类型 无需自定义
$sheet= $objPHPExcel->getSheet(0);
$highestRow= $sheet->getHighestRow(); // 取得总行数
$index= 0;
$hang_tit = empty($hang_tit)?['A'=>'name','B'=>'title','C'=>'phone','D'=>'sex']:$hang_tit;
$list= [];
for($start_get;$start_get<=$highestRow;$start_get++)
{
foreach ($hang_tit as $k=>$v){
$list[$index][$v]= trim($objPHPExcel->getActiveSheet()->getCell($k.$start_get)->getValue());//获取A列的值
}
$index++;
}
return $list;
}
private function _remerge($arr, $let, $field)
{
$letr= [];$year= $arr[0][$field];$s= 3;$e= 2;
foreach ($arr as $k=> $v) {
if ($v[$field]!= $year) {$letr[]= "$let" . $s. ":$let" . $e. "";$e++;
$year= $v[$field];$s= $e;
}else {
$e++;if (count($arr)== ($k+ 1)) {$letr[]= "$let" . $s. ":$let" . $e. "";}
}
}
return $letr;
}
}