PHPOffice/PhpSpreadsheet的导入导出操作基本使用

1.composer 安装

composer require phpoffice/phpspreadsheet(会自动根据当前的php环境变量安装对应的版本)
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
use PhpOffice\PhpSpreadsheet\Reader\Xls;

3.基础使用说明

composer require phpoffice/phpspreadsheet

require_once __DIR__ . '/phpoffice/vendor/autoload.php'; use PhpOffice\PhpSpreadsheet\Spreadsheet; use PhpOffice\PhpSpreadsheet\Worksheet\Drawing; use PhpOffice\PhpSpreadsheet\Style\Alignment; use PhpOffice\PhpSpreadsheet\Style\Fill; use PhpOffice\PhpSpreadsheet\Style\Border; use PhpOffice\PhpSpreadsheet\Style\Color; use PhpOffice\PhpSpreadsheet\IOFactory; use PhpOffice\PhpSpreadsheet\Helper\Html as HtmlHelper; use PhpOffice\PhpSpreadsheet\Cell\DataType; use PhpOffice\PhpSpreadsheet\Worksheet\PageSetup; $spreadsheet = new Spreadsheet(); //新建文件 // $spreadSheet = IOFactory::load($inputFileName); //载入文件 $sheet = $spreadsheet->getActiveSheet(); //$spreadSheet->getProperties()->setCreator("hellow");//设置作者 //$spreadSheet->getSheetCount();//工作表总数 //$spreadSheet->getSheetNames();//工作表名数组 //$sheet = $spreadSheet->getSheetByName('Sheet1');//根据表名获取工作表 //$sheet = $spreadSheet->getSheet(0);//根据表索引获取工作表 //$sheet = $spreadSheet->setActiveSheetIndex(0);//切换当前工作表 //$sheet = $spreadsheet->setActiveSheetIndexByName('DataSheet') //设置打印选项 $sheet->getPageSetup()->setFitToWidth(1); $sheet->getPageSetup()->setFitToHeight(0); $sheet->getPageSetup()->setOrientation(PageSetup::ORIENTATION_LANDSCAPE)->setPaperSize(PageSetup::PAPERSIZE_A4);; $sheet->getPageMargins()->setTop(1)->setRight(0.75)->setLeft(0.75)->setBottom(1); $sheet->getPageSetup()->setHorizontalCentered(true)->setVerticalCentered(false); $sheet->setPrintGridlines(true); $sheet->getPageSetup()->setPrintArea('A1:E5,G4:M20'); //设置缩放 $sheet->getSheetView()->setZoomScale(75); //设置worksheet的颜色 $sheet->getTabColor()->setRGB('FF0000'); //设置worksheet名字 $sheet->setTitle('sheet 1'); //设置默认样式 $spreadsheet->getDefaultStyle()->getFont()->setName('Arial'); $spreadsheet->getDefaultStyle()->getFont()->setSize(8); //获取文档所有值 $data = $sheet->toArray(); //获取最大行数 $res = $sheet->getHighestRow(); //获取最大列数 $res = $sheet->getHighestColumn(); //单元格信息 $cell = $sheet->getCellByColumnAndRow(2, 1); //获取单元格 B1 $cell = $sheet->getCell('A1'); //获取单元格A1 $cell->getValue(); //获取单元格的数据值 $cell->getCoordinate(); //获取行列信息 A1 $column = $cell->getColumn(); //获取列信息 A $row = $cell->getRow(); //获取行信息 1 $cell->getDataType(); //获取数据类型 $cell->setValue('8888'); //设置值 $cell->getStyle()->getFont()->getName(); //单元格样式 //设置行高 $sheet->getDefaultRowDimension()->setRowHeight(10, 'mm'); $sheet->getRowDimension(1)->setRowHeight(10, 'mm'); //设置列宽 // $sheet->getColumnDimension('A')->setAutoSize(true); //$sheet->getColumnDimension('A')->setWidth(300);//设置A列的宽度 $sheet->getDefaultColumnDimension()->setWidth(20); //设置列默认宽度 //设置换行 $sheet->setCellValue('A2', "hellow\nphp"); //设置换行 双引号+\n+setWrapText $sheet->getStyle('A2')->getAlignment()->setWrapText(true); //设置换行 //合并拆分单元格 $sheet->mergeCells('B2:B3'); // $sheet->unmergeCells('B2:B3'); //设置值 // $sheet->setCellValue('A1', "hellow\nphp"); $sheet->setCellValueByColumnAndRow(2, 2, '6666'); //设置B2的值 // $sheet->fromArray($arr, null, 'D5'); //数组,空值时填充值,开始单元格坐标 //设置超链接 $sheet->setCellValue('B3', "百度"); //设置A链接 $sheet->getCell('B3')->getHyperlink()->setUrl('https://www.baidu.com'); // $sheet->setCellValue('E26', 'www.phpexcel.net'); // $sheet->getCell('E26')->getHyperlink()->setUrl("sheet://'Sheetname'!A1"); //设置字体粗细大小颜色 $sheet->getStyle('B3')->getFont()->setBold(true)->setName('Arial')->setSize(20); $sheet->getStyle('B3')->getFont()->getName(); //字体名 $sheet->getStyle('B3')->getFont()->getColor()->setRGB('#AEEEEE'); //设置颜色 $sheet->getStyle('B3')->getFont()->getColor()->getRGB(); //获取颜色值 $sheet->getCell('C3')->setValue('2021-03-27 23:22:59'); //$sheet->getStyle('D2')->getNumberFormat()->setFormatCode(NumberFormat::FORMAT_DATE_DDMMYYYY);//设置日期格式 $sheet->getStyle('D3')->getNumberFormat()->setFormatCode('dd/mm/yyyy'); //设置日期格式 与上文相同 //设置单元格背景色 $sheet->getStyle('E3')->getFill()->setFillType(Fill::FILL_SOLID)->getStartColor()->setARGB(Color::COLOR_GREEN); //设置单元格对齐方式 $sheet->getStyle('B2')->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER); $sheet->getStyle('B2')->getAlignment()->setVertical(Alignment::VERTICAL_CENTER); //设置单元格边框 $sheet->getStyle('C2:E2')->getBorders()->getBottom()->setBorderStyle(Border::BORDER_THIN); //富文本 $html = '<strong>bold</strong>, <em>italic</em>, <strong><em>bold+italic</em></strong>';; $wizard = new HtmlHelper(); $richText = $wizard->toRichTextObject($html); $sheet->setCellValue('D5', $richText); $sheet->setCellValue('A4', '=IF(C4>500,"profit","loss")'); // $formula = $sheet->getCell('A4')->getValue(); // $value = $sheet->getCell('A4')->getCalculatedValue(); //插入删除行列 $sheet->insertNewRowBefore(7, 2); $sheet->removeRow(7, 2); //写入图片 $drawing = new Drawing(); $drawing->setName('Logo')->setDescription('Logo')->setPath('../files/1.jpg')->setHeight(30)->setCoordinates('D6')->setOffsetX(50)->setOffsetY(6); $drawing->setRotation(25); $drawing->getShadow()->setVisible(true); $drawing->getShadow()->setDirection(45); $drawing->setWorksheet($sheet); //设置单元格数据类型 $sheet->getCell('A1')->setValueExplicit('25', DataType::TYPE_NUMERIC); $styleArray = [ 'font' => [ 'bold' => true, 'alignment' => [ 'horizontal' => Alignment::HORIZONTAL_RIGHT, 'borders' => [ 'top' => [ 'borderStyle' => Border::BORDER_THIN, 'fill' => [ 'fillType' => \PhpOffice\PhpSpreadsheet\Style\Fill::FILL_GRADIENT_LINEAR, 'rotation' => 90, 'startColor' => [ 'argb' => 'FFA0A0A0', 'endColor' => [ 'argb' => 'FFFFFFFF', $filename = '01simple.xlsx'; $sheet->getStyle('A5:E5')->applyFromArray($styleArray); // // 保存xlsx在本地 // $writer = IOFactory::createWriter($spreadsheet, 'Xlsx'); // $writer->save('01simple.xlsx'); // 下载xlsx header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); header('Content-Disposition: attachment;filename="' . $filename . '"'); header('Cache-Control: max-age=0'); header('Cache-Control: max-age=1'); 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 $writer = IOFactory::createWriter($spreadsheet, 'Xlsx'); $writer->save('php://output'); exit;
require_once __DIR__ . './phpoffice/vendor/autoload.php';
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Helper\Html as HtmlHelper;
$spreadsheet = new Spreadsheet(); //新建文件
$sheet = $spreadsheet->getActiveSheet();
//富文本
$html = '<strong>bold</strong>, <em>italic</em>, <strong><em>bold+italic</em></strong>';;
$wizard = new HtmlHelper();
$richText = $wizard->toRichTextObject($html);
$sheet->setCellValue('D5', $richText);
$filename = 'aa.xlsx';
// 下载xlsx
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="' . $filename . '"');
header('Cache-Control: max-age=0');
header('Cache-Control: max-age=1');
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
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
$writer->save('php://output');
exit;
$filename = 'aa.xlsx';
$htmlString = '<table border="1" style="width: 100%; margin-bottom: 1rem; color: #212529;vertical-align: top;border-color: #dee2e6;border-collapse: collapse;border: 1px solid black;">
            <thead>
                <tr style="height: 4rem;">
                    <th>#</th>
                    <th>First</th>
                    <th>Last</th>
                    <th>Handle</th>
            </thead>
            <tbody>
                <tr style="height: 3rem;">
                    <th scope="row"><input type="checkbox"></th>
                    <td>Mark</td>
                    <td>Otto</td>
                    <td>@mdo</td>
                <tr style="height: 3rem;">
                    <th scope="row"><input type="checkbox"></th>
                    <td>Jacob</td>
                    <td>Thornton</td>
                    <td>@fat</td>
                <tr style="height: 3rem;">
                    <th><input type="checkbox"></th>
                    <td colspan="2">Larry the Bird</td>
                    <td>@twitter</td>
            </tbody>
        </table>';
$reader = new \PhpOffice\PhpSpreadsheet\Reader\Html();
$spreadsheet = $reader->loadFromString($htmlString);
// 下载xlsx
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename="' . $filename . '"');
header('Cache-Control: max-age=0');
header('Cache-Control: max-age=1');
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
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
$writer->save('php://output');
exit;
require_once __DIR__ . '/phpoffice/vendor/autoload.php';
use PhpOffice\PhpSpreadsheet\IOFactory; //用于载入已有的模板文件
$inputFileName = '../files/temp-sample-v0.xlsx'; //一个空的excel文件
$spreadsheet = IOFactory::load($inputFileName);
$sheet = $spreadsheet->getActiveSheet();
$sheet->setCellValue('B5', '12345677');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="myfile.xls"');
header('Cache-Control: max-age=0');