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

按理說從第二行開始,這條語句輸出的結果應該為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與字符串“消息”比較,這時可以發現,它們終於相等瞭。

You May Also Like