天天看點

php提取csv格式檔案中的字元串出現的問題及解決辦法

php帶csv格式的資料要用到fgetcsv()函數。

用這下面的語句

打開一個test.csv格式的檔案,檔案中的内容以","号分開。

取出的第一行代表自動含義,比如 id,messaget,time等等。

從第二行開始表示具體的資料,比如1,消息,12:00。

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

繼續閱讀