如何解决php excel reader导出excel中文乱码?

coldplay.xixi
发布: 2020-07-13 13:05:15
原创
3756人浏览过
解决php excel reader导出excel中文乱码的方法:1、如果不使用dump函数,可以通过修改【_defaultEncoding】变量解决问题;2、如果使用dump函数导出excel,需要修改htmlentities函数解决。

如何解决php excel reader导出excel中文乱码?

解决php excel reader导出excel中文乱码的方法:

在下载完php excel reader2.21后,请解压至你的PHP环境配置的运行目录下,打开example.php,首先来看

1$data=new Spreadsheet_Excel_Reader("example.xls");
登录后复制
登录后复制

此语句是用来创建一个php导出excel的实例,在excel_reader2.php文件中我们可以找到此php excel reader类的构造函数原型

Spreadsheet_Excel_Reader($file='',$store_extended_info=true,$outputEncoding='')
登录后复制

顾名思义,php excel reader导出excel文件内容的编码类型是通过$outputEncoding参数来指定的,默认的php excel reader导出excel的编码类型是通过变量_defaultEncoding设定,默认为UTF-8,所以通常解决php excel reader导出excel中文乱码有两种方法。

立即学习PHP免费学习笔记(深入)”;

php excel reader导出excel中文乱码解决方法一:

1$data=new Spreadsheet_Excel_Reader("example.xls");
登录后复制
登录后复制

改为

1$data=new Spreadsheet_Excel_Reader("example.xls",true,"GB2312");
登录后复制

php excel reader导出excel中文乱码解决方法二:

打开excel_reader2.php,找到

1var$_defaultEncoding="UTF-8";
登录后复制

修改为

1var$_defaultEncoding="GB2312";
登录后复制

即可解决php excel reader导出excel乱码的问题。

那为什么通过上述教程修改后,如果在example.xls中添加中文后example.php仍然输出乱码呢?

这是因为其调用了php excel reader类中的dump函数,此函数是用来将导出的excel文件内容以HTML的形式输出,而问题恰恰是由于这个函数中htmlentities函数作怪,htmlentities函数是用来把字符转换为HTML实体的,原型如下

htmlentities(string,quotestyle,character-set)
登录后复制

其默认的字符集为ISO-8859-1,所以当使用php excel reader的dump函数导出excel出现中文乱码时,

解决方法一:

1$val=htmlentities($val);
登录后复制
登录后复制

修改为

1$val=htmlentities($val,ENT_COMPAT,"GB2312");
登录后复制

解决方法二:

1$val=htmlentities($val);
登录后复制
登录后复制

修改为

1$val=htmlspecialchars($val);
登录后复制

php excel reader导出excel中文乱码解决方法总结

  如果不使用dump函数导出excel,可以通过修改_defaultEncoding变量或者通过new Spreadsheet_Excel_Reader(excel文件名,true,”GB2312″);解决导出excel乱码问题,如果使用dump函数以HTML的方式导出excel,需要修改htmlentities函数解决导出excel乱码问题。

相关学习推荐:PHP编程从入门到精通

以上就是如何解决php excel reader导出excel中文乱码?的详细内容,更多请关注php中文网其它相关文章!

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号