程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
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