php读取csv文件后,uft8 bom导致在页面上显示出现问题的解决方法


Posted in PHP onAugust 10, 2013

date.csv:
"ID" "NAME" "EMAIL"
"1" "小明" "xm@163.com"
"2" "小东" "xd@sina.com"
"3" "小少" "shaozi@hotmai.com"

读取这个csv文件

<?php
$handle=fopen('date.csv','r');
while($data=fgetcsv($handle,10000,"/t"))   
{   
  echo "$data[0]"."$data[1]"."$data[2]";   
}
?>

读取后在页面上显示时,成了这样:
"ID" NAME EMAIL
 1 小明 xm@163.com
 2 小东 xd@sina.com
 3 小少 shaozi@hotmai.com
fgetcsv函数的字段环绕符默认是双引号,
为什么我读取出来时,其它字段都好好的,可是ID还有双引号包着?

上网查了下,原来是utf8编码的bom在php下无法识别.
下面是查来的资料:
Unicode规范中有一个BOM的概念。BOM——Byte Order Mark,就是字节序标记。在
这里
找到一段关于BOM的说明:
在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输字符"ZERO WIDTH NO-BREAK SPACE"。这样如果接收者收到FEFF,就表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little-Endian的。因此字符"ZERO WIDTH NO-BREAK SPACE"又被称作BOM。

UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。字符"ZERO WIDTH NO-BREAK SPACE"的UTF-8编码是EF BB BF。所以如果接收者收到以EF BB BF开头的字节流,就知道这是UTF-8编码了。
Windows就是使用BOM来标记文本文件的编码方式的。

另外unicode网站的
FAQ-BOM
详细介绍了BOM。官方的自然权威,不过是英文的,看起来比较费劲。
UTF-8编码的文件中,BOM占三个字节。如果用记事本把一个文本文件另存为UTF-8编码方式的话,用UE打开这个文件,切换到十六进制编辑状态就可以看到开头的FFFE了。这是个标识UTF-8编码文件的好办法,软件通过BOM来识别这个文件是否是UTF-8编码,很多软件还要求读入的文件必须带BOM。可是,还是有很多软件不能识别BOM。我在研究Firefox的时候就知道,在Firefox早期的版本里,扩展是不能有BOM的,不过Firefox 1.5以后的版本已经开始支持BOM了。现在又发现,PHP也不支持BOM。

PHP在设计时就没有考虑BOM的问题,也就是说他不会忽略UTF-8编码的文件开头BOM的那三个字符。由于必须在转换->UTF-8转ASCII,或者在另存为里选择ASCII编码。如果是DOS格式的行尾符,可以用记事本打开,点另存为,选ASCII编码。如果包含中文字符的话,可以用UE的另存为功能,选择“UTF-8 无 BOM”即可。请参考下面的图片:
php读取csv文件后,uft8 bom导致在页面上显示出现问题的解决方法

根据Bo-Blog的wiki的说明:Editplus需要先另存为gb,再另存为UTF-8。不过这样做要小心,所有GBK编码中不包含的字符就会都丢了。如果有一些非中文的字符在文件里的话还是不要用这种办法了。(从这一个小方面来看,UE——UltraEdite-32确实比Editplus好很多,Editplus太轻量级了)

另外我发现了一个办法,就是利用Wordpress提供的文件编辑器。这个办法不受限制,不需要去下载专门的编辑器,毕竟大家都在用Wordpress嘛。先在ftp里把要编辑的文件的写入权限打开,然后进入Wordpress后台->管理->文件编辑器,输入要编辑文件的路径,点编辑文件。在显示出来的编辑界面中,你是看不到开头的那三个字符的,不过没关系,把光标定位在整个文件的第一个字符前,按一下Backspace键。OK了,点更新文件吧,在ftp里刷新一下,可以看到文件小了3字节,大功告成。

最后说一下,这是个大问题,所有要自己写插件的,编辑别人的插件自己用的,需要修改模版的(这条估计每个人都需要吧),最好了解一下上面的知识,免得出现问题时不知所措。

PHP 相关文章推荐
php array_merge下进行数组合并的代码
Jul 22 PHP
php图片加中文水印实现代码分享
Oct 31 PHP
PHP Curl多线程原理实例详解
Nov 06 PHP
php获取域名的google收录示例
Mar 24 PHP
php实现文件下载实例分享
Jun 02 PHP
Linux下创建nginx脚本-start、stop、reload…
Aug 03 PHP
PHP curl CURLOPT_RETURNTRANSFER参数的作用使用实例
Feb 07 PHP
php递归遍历删除文件的方法
Apr 17 PHP
Yii清理缓存的方法
Jan 06 PHP
详解PHP的Yii框架中自带的前端资源包的使用
Mar 31 PHP
PHP+ajax实现二级联动菜单功能示例
Aug 10 PHP
Yii2语言国际化的配置教程
Aug 19 PHP
浅析php中常量,变量的作用域和生存周期
Aug 10 #PHP
浅析linux下apache服务器的配置和管理
Aug 10 #PHP
本地机apache配置基于域名的虚拟主机详解
Aug 10 #PHP
php 删除目录下N分钟前创建的所有文件的实现代码
Aug 10 #PHP
php中如何判断一个网页请求是ajax请求还是普通请求
Aug 10 #PHP
php一些错误处理的方法与技巧总结
Aug 10 #PHP
Zend Studio 实用快捷键一览表(精心整理)
Aug 10 #PHP
You might like
php入门之连接mysql数据库的一个类
2012/04/21 PHP
php curl登陆qq后获取用户信息时证书错误
2015/02/03 PHP
PHP表单提交后引号前自动加反斜杠的原因及三种办法关闭php魔术引号
2015/09/30 PHP
PHP5.5.15+Apache2.4.10+MySQL5.6.20配置方法分享
2016/05/06 PHP
laravel5实现微信第三方登录功能
2018/12/06 PHP
解javascript 混淆加密收藏
2009/01/16 Javascript
[Web]防止用户复制页面内容和另存页面的方法
2009/02/06 Javascript
JS实现悬浮移动窗口(悬浮广告)的特效
2013/03/12 Javascript
JavaScript输入邮箱自动提示实例代码
2014/01/13 Javascript
jQuery选择器全集详解
2014/11/24 Javascript
ubuntu下安装nodejs以及升级的办法
2015/05/08 NodeJs
vue,angular,avalon这三种MVVM框架优缺点
2016/04/27 Javascript
AngularJS创建自定义指令的方法详解
2016/11/03 Javascript
jQuery实现web页面樱花坠落的特效
2017/06/01 jQuery
集成vue到jquery/bootstrap项目的方法
2018/02/10 jQuery
JS字符串去除连续或全部重复字符的实例
2018/03/08 Javascript
layui 优化button按钮和弹出框的方法
2018/08/15 Javascript
详解template标签用法(含vue中的用法总结)
2021/01/12 Vue.js
[12:51]71泪洒现场!是DOTA2让经典重现
2014/03/24 DOTA
[01:23]2014DOTA2国际邀请赛 球迷无处不在Ti现场世界杯受关注
2014/07/10 DOTA
python多线程扫描端口示例
2014/01/16 Python
在Python中使用SimpleParse模块进行解析的教程
2015/04/11 Python
python使用xmlrpclib模块实现对百度google的ping功能
2015/06/02 Python
Python将阿拉伯数字转换为罗马数字的方法
2015/07/10 Python
Python第三方库的安装方法总结
2016/06/06 Python
python递归全排列实现方法
2018/08/18 Python
python实现录屏功能(亲测好用)
2020/03/02 Python
Python如何对XML 解析
2020/06/28 Python
面向新手解析python Beautiful Soup基本用法
2020/07/11 Python
俄罗斯极限运动网上商店:Board Shop №1
2020/12/18 全球购物
群众路线党课主持词
2014/04/01 职场文书
2014年护士工作总结范文
2014/11/11 职场文书
商场收银员岗位职责
2015/04/07 职场文书
读书笔记格式
2015/07/02 职场文书
关于MySQL中的 like操作符详情
2021/11/17 MySQL
在容器中使用nginx搭建上传下载服务器
2022/05/11 Servers