[PHP] Verwenden Sie PHPSpreadsheet, um Daten in eine Excel-Datei auszugeben

little bottle
Freigeben: 2023-04-06 06:56:01
nach vorne
4594 Leute haben es durchsucht

In diesem Artikel stellen wir vor, wie Sie mit PHPSpreadsheet Daten als Referenz in eine Excel-Datei ausgeben.

Bevor wir PHP zum Exportieren von Excel-Daten verwendet haben, haben wir die PHPExcel-Bibliothek verwendet, aber phpoffice hat offiziell angekündigt, dass PHPExcel aufgegeben wurde und nicht mehr gepflegt wird. Es wird empfohlen, PHPSpreadsheet zu verwenden, wie in der Abbildung gezeigt unten

[PHP] Verwenden Sie PHPSpreadsheet, um Daten in eine Excel-Datei auszugeben

Wir können PHPSpreadsheet über Composer installieren

[PHP] Verwenden Sie PHPSpreadsheet, um Daten in eine Excel-Datei auszugeben

composer require phpoffice/phpspreadsheet
Nach dem Login kopieren

Verwenden Sie PHPSpreadsheet, um Studenteninformationen in das Browser-Codebeispiel zu exportieren

/**
 * 输出到浏览器(需要设置header头)
 * @param string $fileName 文件名
 * @param string $fileType 文件类型
 */
function excelBrowserExport($fileName, $fileType) {

    //文件名称校验
    if(!$fileName) {
        trigger_error('文件名不能为空', E_USER_ERROR);
    }

    //Excel文件类型校验
    $type = ['Excel2007', 'Xlsx', 'Excel5', 'xls'];
    if(!in_array($fileType, $type)) {
        trigger_error('未知文件类型', E_USER_ERROR);
    }

    if($fileType == 'Excel2007' || $fileType == 'Xlsx') {
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        header('Content-Disposition: attachment;filename="'.$fileName.'.xlsx"');
        header('Cache-Control: max-age=0');
    } else { //Excel5
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="'.$fileName.'.xls"');
        header('Cache-Control: max-age=0');
    }
}

$data = [
    [1, 'jack', 10],
    [2, 'mike', 12],
    [3, 'jane', 21],
    [4, 'paul', 26],
    [5, 'kitty', 25],
    [6, 'yami', 60],
];

$title = ['id', 'name', 'age'];

$spreadsheet = new Spreadsheet();
$worksheet = $spreadsheet->getActiveSheet();

//设置工作表标题名称
$worksheet->setTitle('工作表格1');

//表头
//设置单元格内容
foreach ($title as $key => $value) {
    $worksheet->setCellValueByColumnAndRow($key+1, 1, $value);
}

$row = 2; //从第二行开始
foreach ($data as $item) {
    $column = 1;

    foreach ($item as $value) {
        $worksheet->setCellValueByColumnAndRow($column, $row, $value);
        $column++;
    }
    $row++;
}


$fileName = '学生信息';
$fileType = 'Xlsx';

//1.下载到服务器
//$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
//$writer->save($fileName.'.'.$fileType);

//2.输出到浏览器
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx'); //按照指定格式生成Excel文件
excelBrowserExport($fileName, 'Xlsx');
$writer->save('php://output');
Nach dem Login kopieren

Das Exportergebnis ist wie in der Abbildung dargestellt:

[PHP] Verwenden Sie PHPSpreadsheet, um Daten in eine Excel-Datei auszugeben

Verwandte Tutorials: PHP-Video-Tutorial

Das obige ist der detaillierte Inhalt von[PHP] Verwenden Sie PHPSpreadsheet, um Daten in eine Excel-Datei auszugeben. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage