php关于phpexcel乱码问题


导出excel文件  出现了一个问题 在导出行数5行以上的时候 导出数据格式正常  在5行一下数据的时候 中文全部乱码  这个问题请教各位大神  代码贴出来下面
$filename='exceptionOrder'.date('Y-m-d');
        header("Content-type:application/octet-stream");
        header("Accept-Ranges:bytes");
        header("Content-type:application/vnd.ms-excel;charset=UTF-8");
        header("Content-Disposition:attachment;filename=".$filename.".xls");
        header("Pragma: no-cache");
        header("Expires: 0");
        $table = '';
        $table.='<html  xmlns:x="urn:schemas-microsoft-com:office:excel" ><table cellpadding="0" cellspacing="0" border="1" style="br:mso-data-placement:same-cell;">'.PHP_EOL;
        $table.='<thead>
            <tr>
            <td style="font-size:14px;font-weight:bold;padding:5px;">序号'.iconv("gb2312","UTF-8",'序号').'</td>
            <td style="font-size:14px;font-weight:bold;padding:5px;">SKU</td>
<td style="font-size:14px;font-weight:bold;padding:5px;">仓库</td>
            <td style="font-size:14px;font-weight:bold;padding:5px;">库位</td>
            <td style="font-size:14px;font-weight:bold;padding:5px;">实库存</td>
            </tr>
            </thead>'.PHP_EOL;
$i = 1;
        foreach($data as $key =>$val){
if($val['orders_warehouse_id']==1000){
$str =  "深圳一仓";
}else if($val['orders_warehouse_id']==1025){
$str =  "义乌仓";
  }
        $table.='<tr><td>'.$i.'</td>
                     <td>'.$val['product_sku'].'</td>
<td>'.$str.'</td>
                     <td>'.$val['products_location'].'</td>
                     <td>'.$val['actual_stock'].'</td>'.PHP_EOL;
$i++;    //序号自增
        }
        $table.='</table></html>'.PHP_EOL;
        echo $table;

6 个解决方案

#1


没看到在哪里用了 phpexcel

#2


转下码就行了

#3


楼上两位都不对   请看清问题

#4




应该是你数据库出来的时候已经有问题了

#5


fwrite($fp, chr(0xEF).chr(0xBB).chr(0xBF)); // 添加 BOM

如果导出csv格式的话,在WPS上都正常,就是在MS office上会乱码。加上这个就正常了。我也是最近才知道的。

#6


$table  = pack("C3",239,187,191);

试下行不。为啥你用html格式展示呢,我通常是用csv格式,让文件下载的。
智能推荐

注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
© 2014-2019 ITdaan.com 粤ICP备14056181号  

赞助商广告