程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php提取csv格式文件中的字符串出現的問題及解決辦法

php提取csv格式文件中的字符串出現的問題及解決辦法

編輯:關於PHP編程

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與字符串“消息”比較,這時可以發現,它們終於相等了。


  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved