PHPExcel操作excel

本文详细介绍了使用PHPExcel库进行Excel文件的导出与导入操作,包括基本操作、样式控制及数据加载技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.导出文件基本操作

<?php

$dir = dirname(__FILE__);

// 引入插件类
require $dir . '/Class/PHPExcel.php';

// 实例化类
$objExcel = new PHPExcel();

// 创建新页,此时有两个页,第一页是默认存在的
$objExcel->createSheet();

// 设置当前页
$objExcel->setActiveSheetIndex(0);

// 获取当前页对象,默认为0
$objSheet = $objExcel->getActiveSheet();

// 设置当前页的标题
$objSheet->setTitle('demo');

// 填充单元格的指
$objSheet->setCellValue('A1', '姓名')->setCellValue('B1', '分数');
$objSheet->setCellValue('A2', '张三')->setCellValue('B2', '90');

// 保存本地文件
// $objWrite = PHPExcel_IOFactory::createWriter($objExcel, 'Excel5');  // .xls
$objWrite = PHPExcel_IOFactory::createWriter($objExcel, 'Excel2007');  // .xlsx
$objWrite->save($dir . '/demo.xlsx');

// 输出到浏览器
// set_header('Excel5', 'demo.xls');
// $objWrite->save('php://output');

function set_header($type, $filename) {
    if($typ == 'Excel5') {
        header('Content-Type: application/vnd.ms-excel');
    }else {
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
    }

    header('Content-Disposition: attachment;filename="' . $filename . '"');
    header('Cache-Control: max-age=0');
}


2.基本样式控制

2.1文字对齐
// 默认样式
$objExcel->getDefaultStyle()->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER)->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

$objSheet->getStyle('A1:C3')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER)->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

2.2 合并单元格
$objSheet->mergeCells('A1:C3');
$objSheet->unmergeCells('A1:C3');
2.3 设置字体和大小
$objSheet->getStyle('A1:Z1')->getFont()->setName('微软雅黑')->setSize(20);
2.4 设置字体颜色
$objSheet->getStyle('A1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_RED);
2.5 设置背景颜色
$objSheet->getStyle('A1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID)->getStartColor()
         ->setARGB('FFC9C9C9');
2.6 设置边框
$styleArr = [
    'borders' => [
        'outline' => [
            'style' => PHPExcel_Style_Border::BORDER_THICK,
            'color' => ['argb' => 'FF000000']
        ]
    ]
];

$objSheet->getStyle('A1')->applyFromArray($styleArr);
2.7 设置换行
$objSheet->getStyle('A')->getAlignment()->setWrapText(true);
$objSheet->setCellValue('A1', "hello\nworld");
2.8 显示单元格显示格式
$objSheet->setCellValueExplicit ('A1', 162736712637162, PHPExcel_Cell_DataType::TYPE_STRING);

3. 导入Excel文件

3.1 加载全部页
<?php

$dir = dirname(__FILE__);

// 引入插件类
require $dir . '/Class/PHPExcel/IOFactory.php';

$filename = $dir . '/demo.xlsx';

// 全部加载
$objExcel = PHPExcel_IOFactory::load($filename);

// for循环加载数据
$sheetCount = $objExcel->getSheetCount();
for($i = 0; i < $sheetCount; $i++) {
    $data = $objExcel->getSheet($i)->toArray();
    print_r($data);
}

// 用迭代器加载数据
foreach($objExcel->getWorksheetIterator() as $sheet) {
    foreach($sheet->getRowIterator() as $row) {
        foreach($row->getCellIterator() as $cell) {
            $data = $cell->getValue();
            echo $data . ' ';
        }
        echo '<br/>';
    }
    echo '<br/>';
}
3.2 部分加载页
$filename = $dir . '/demo.xlsx';
$fileType = PHPExcel_IOFactory::identify($filename);
$objReader = PHPExcel_IOFactory::createReader($fileType);
$sheetName = ['成绩'];
$objReader->setLoadSheetsOnly($sheetName);
// 部分加载
$objExcel = $objReader->load($filename);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值