首页 > 代码库 > php提取csv格式文件中的字符串出现的问题及解决办法
php提取csv格式文件中的字符串出现的问题及解决办法
php带csv格式的数据要用到fgetcsv()函数。
用这下面的语句
$hd=fopen(‘test.csv‘,‘r‘); $buf=fgetcsv($hd,1000,‘,‘);打开一个test.csv格式的文件,文件中的内容以","号分开。
取出的第一行代表自动含义,比如 id,messaget,time等等。
从第二行开始表示具体的数据,比如1,消息,12:00。
if($buf[1]=="some messages") echo "yes";
这是为什么呢?
可以用strlen()函数来比较$buf[1]与“消息”的长度。
比较的结果竟然是不相等。
天啊,怎么会出现这种问题呢?明明第二行$buf[1]取出来的值是“消息”啊,怎么会长度不一样呢?
这与你的csv格式文件的编码方式有关。
怎么解决这个问题呢?
先用php的字符编码检测函数mb_detect_encoding($buf[1],‘UTF-8,EUC-CN,ASSII‘),
如果取出来的编码格式为“EUC-CN”,那就哟个下面的语句将其转换为utf8的编码格式,
用php的字符转换函数mb_convert_encoding(),$res=mb_convert_encoding($buf[1],‘UTF-8‘,‘EUC-CN‘)。
将转换的结果$res与字符串“消息”比较,这时可以发现,它们终于相等了。
php提取csv格式文件中的字符串出现的问题及解决办法
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。