Maison  >  Article  >  développement back-end  >  Comment résoudre le code chinois tronqué lors du téléchargement d'Excel en PHP

Comment résoudre le code chinois tronqué lors du téléchargement d'Excel en PHP

PHPz
PHPzoriginal
2023-04-06 09:14:431164parcourir

Lors du développement, il est souvent nécessaire d'utiliser PHP pour générer des fichiers Excel et les proposer aux utilisateurs en téléchargement. Cependant, nous rencontrerons souvent un problème, c'est-à-dire que des caractères tronqués apparaissent lors de la sortie du chinois. Ci-dessous, nous présenterons les causes et les solutions des caractères chinois tronqués.

1. Analyse des causes

L'apparition de caractères chinois tronqués est principalement due au jeu de caractères incohérent du fichier. Lorsque nous sortons le fichier Excel généré par PHP vers le navigateur, nous devons spécifier le jeu de caractères de sortie, et le jeu de caractères du fichier Excel doit être cohérent avec le jeu de caractères de sortie, sinon des caractères tronqués apparaîtront.

2. Solution

  1. Paramètre du jeu de caractères du fichier PHP

Dans le fichier PHP, nous devons définir le jeu de caractères du fichier. Habituellement, le jeu de caractères UTF-8 est davantage utilisé. Vous pouvez ajouter le code suivant au code PHP :

header("Content-Type:text/html;charset=utf-8");
  1. Paramètre du jeu de caractères du fichier Excel

Lors de la génération d'un fichier Excel, nous devons définir le jeu de caractères du fichier pour qu'il soit cohérent avec le jeu de caractères de sortie. Vous pouvez définir le jeu de caractères du fichier Excel en appelant la méthode fournie par la bibliothèque PHPExcel. L'exemple de code est le suivant :

<?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');

Dans le code ci-dessus, nous configurons le fichier Excel en appelant la méthode de définition des propriétés du fichier fournie par. l'objet PHPExcel, puis appelez PHPExcel. La méthode setActiveSheetIndex fournie par l'objet définit la feuille actuelle comme première et écrit les données dans Excel en appelant la méthode setCellValue. Ensuite, nous obtenons la feuille actuelle en appelant la méthode getActiveSheet, puis appelons la méthode setTitle pour définir le titre du fichier, et obtenons le commentaire de la cellule actuelle en appelant la méthode getComment, et utilisons la méthode setText pour définir la valeur d'attribut pour le Propriété de police du commentaire et définition du jeu de caractères Excel. Enfin, le fichier Excel est affiché dans le navigateur en appelant la méthode header.

Ce qui précède est une solution au problème des caractères chinois tronqués dans les fichiers Excel téléchargés par PHP. En définissant le jeu de caractères du fichier, l'effet des caractères tronqués peut être évité.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn