Heim  >  Artikel  >  Backend-Entwicklung  >  So lösen Sie den verstümmelten chinesischen Code beim Herunterladen von Excel in PHP

So lösen Sie den verstümmelten chinesischen Code beim Herunterladen von Excel in PHP

PHPz
PHPzOriginal
2023-04-06 09:14:431208Durchsuche

Während der Entwicklung ist es häufig erforderlich, PHP zu verwenden, um Excel-Dateien zu generieren und diese für Benutzer zum Herunterladen bereitzustellen. Allerdings stoßen wir oft auf ein Problem, nämlich dass bei der chinesischen Ausgabe verstümmelte Zeichen erscheinen. Im Folgenden stellen wir die Ursachen und Lösungen für verstümmelte chinesische Schriftzeichen vor.

1. Ursachenanalyse

Das Auftreten verstümmelter chinesischer Zeichen ist hauptsächlich auf den inkonsistenten Zeichensatz der Datei zurückzuführen. Wenn wir die von PHP generierte Excel-Datei an den Browser ausgeben, müssen wir den Ausgabezeichensatz angeben. Der Zeichensatz der Excel-Datei muss mit dem Ausgabezeichensatz übereinstimmen, da sonst verstümmelte Zeichen angezeigt werden.

2. Lösung

  1. Zeichensatzeinstellung der PHP-Datei

In der PHP-Datei müssen wir den Zeichensatz der Datei festlegen. Normalerweise wird eher der UTF-8-Zeichensatz verwendet. Sie können dem PHP-Code den folgenden Code hinzufügen:

header("Content-Type:text/html;charset=utf-8");
  1. Zeichensatzeinstellung der Excel-Datei

Beim Generieren einer Excel-Datei müssen wir den Zeichensatz der Datei so einstellen, dass er mit dem Ausgabezeichensatz übereinstimmt. Sie können den Zeichensatz der Excel-Datei festlegen, indem Sie die von der PHPExcel-Bibliothek bereitgestellte Methode aufrufen. Der Beispielcode lautet wie folgt:

<?php
    require_once &#39;PHPExcel.php&#39;;

    //新建一个PHPExcel对象
    $objPHPExcel = new PHPExcel();

    //设置文件属性
    $objPHPExcel->getProperties()
        ->setCreator("Maarten Balliauw")
        ->setLastModifiedBy("Maarten Balliauw")
        ->setTitle("PHPExcel Test Document")
        ->setSubject("PHPExcel Test Document")
        ->setDescription("Test document for PHPExcel, generated using PHP classes.")
        ->setKeywords("office PHPExcel php")
        ->setCategory("Test result file");

    //设置当前的sheet
    $objPHPExcel->setActiveSheetIndex(0);

    //向Excel中写入数据
    $objPHPExcel->getActiveSheet()->setCellValue('A1', 'Hello');
    $objPHPExcel->getActiveSheet()->setCellValue('B1', 'World!');
    $objPHPExcel->getActiveSheet()->setCellValue('C1', '中文测试');

    //设置Excel的字符集
    $objPHPExcel->getActiveSheet()
        ->setTitle('PHPExcel Test Document')
        ->getComment('C1')
        ->setAuthor('PHPExcel')
        ->setText('Test document for PHPExcel, generated using PHP classes.')
        ->getText()->getFont()
        ->setColor(new PHPExcel_Style_Color(PHPExcel_Style_Color::COLOR_BLUE))
        ->setBold(true)
        ->setSize(14)
        ->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);

    //设置Excel的输出格式
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename="test.xls"');
    header('Cache-Control: max-age=0');

    //将Excel文件输出到浏览器
    $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
    $objWriter->save('php://output');

Im obigen Code konfigurieren wir die Excel-Datei, indem wir die von bereitgestellte Methode zum Festlegen von Dateieigenschaften aufrufen das PHPExcel-Objekt und rufen Sie dann PHPExcel auf. Die vom Objekt bereitgestellte setActiveSheetIndex-Methode legt das aktuelle Blatt als erstes fest und schreibt Daten in Excel, indem die setCellValue-Methode aufgerufen wird. Als nächstes rufen wir das aktuelle Blatt ab, indem wir die Methode getActiveSheet aufrufen, rufen dann die Methode setTitle auf, um den Titel der Datei festzulegen, und rufen den Kommentar der aktuellen Zelle ab, indem wir die Methode getComment aufrufen, und verwenden die Methode setText, um den Attributwert für festzulegen Schriftarteigenschaft des Kommentars und Festlegen des Excel-Zeichensatzes. Abschließend wird die Excel-Datei durch den Aufruf der Header-Methode an den Browser ausgegeben.

Das Obige ist eine Lösung für das Problem verstümmelter chinesischer Zeichen in von PHP heruntergeladenen Excel-Dateien. Durch Festlegen des Zeichensatzes der Datei kann der Effekt verstümmelter Zeichen vermieden werden.

Das obige ist der detaillierte Inhalt vonSo lösen Sie den verstümmelten chinesischen Code beim Herunterladen von Excel in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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