Heim >Backend-Entwicklung >PHP-Tutorial >php提取csv格式文件中的字符串出现的问题及解决办法_PHP教程

php提取csv格式文件中的字符串出现的问题及解决办法_PHP教程

WBOY
WBOYOriginal
2016-07-13 10:30:33940Durchsuche

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";


按理说从第二行开始,这条语句输出的结果应该为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与字符串“消息”比较,这时可以发现,它们终于相等了。


www.bkjia.comtruehttp://www.bkjia.com/PHPjc/765066.htmlTechArticlephp带csv式的数据要用到fgetcsv()函数。 用这下面的语句 $hd=fopen('test.csv','r');$buf=fgetcsv($hd,1000,','); 打开一个test.csv式的文件,文件中的内容以...
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn