萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> 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";

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

copyright © 萬盛學電腦網 all rights reserved