PHP Excel将false返回给带有特殊字符的字符串

时间:2015-04-08 17:59:37

标签: php phpexcel

我有一个表格($_POST var)中的几个字符串,其中一些字符串有特殊的字符(ñ,á,é等)。当我使用这些$_POST变量创建Excel文件时,所有单元格都会打印正确的信息,但具有特殊字符的单元格会打印FALSE

这是一段代码:

for ($j=1; $j<$_POST["z"]; $j++) {
$fila_despacho = $j+1;  
$objPHPExcel->setActiveSheetIndex(0)
->setCellValue('A'.$fila_despacho, '03') 
->setCellValue('B'.$fila_despacho, $_POST["servicio".$j])
->setCellValue('C'.$fila_despacho, trim ($_POST["comuna".$j]))
->setCellValue('D'.$fila_despacho, 1)
->setCellValue('E'.$fila_despacho, trim($_POST["nombre".$j]))
->setCellValue('F'.$fila_despacho, trim($_POST["direccion".$j]))
        ->setCellValue('G'.$fila_despacho, trim($_POST["num".$j]));    
}//endfor

关于UTF-8,我不知道如何检查,我是新手。你能告诉我怎么样吗?

1 个答案:

答案 0 :(得分:2)

在设置单元格值之前更改为UTF-8。使用utf8_encode()。例如:

$objPHPExcel->getActiveSheet()->setCellValue('A1', utf8_encode($descripcion));

稍后您可以保存文件,例如:

header('Content-Type: application/vnd.ms-excel;  charset=UTF-8');  
header("Content-Disposition: attachment;filename='$archivo'");