這篇文章主要介紹如何解決php讀取csv文件后uft8 bom導致在頁面上顯示出現(xiàn)問題,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
date.csv:
"ID" "NAME" "EMAIL"
"1" "小明" "xm@163.com"
"2" "小東" "xd@sina.com"
"3" "小少" "shaozi@hotmai.com"
讀取這個csv文件
復制代碼 代碼如下:
<?php
$handle=fopen('date.csv','r');
while($data=fgetcsv($handle,10000,"/t"))
{
echo "$data[0]"."$data[1]"."$data[2]";
}
?>
讀取后在頁面上顯示時,成了這樣:
"ID" NAME EMAIL
1 小明 xm@163.com
2 小東 xd@sina.com
3 小少 shaozi@hotmai.com
fgetcsv函數(shù)的字段環(huán)繞符默認是雙引號,
為什么我讀取出來時,其它字段都好好的,可是ID還有雙引號包著?
上網(wǎng)查了下,原來是utf8編碼的bom在php下無法識別.
下面是查來的資料:
Unicode規(guī)范中有一個BOM的概念。BOM——Byte Order Mark,就是字節(jié)序標記。在
這里
找到一段關于BOM的說明:
在UCS 編碼中有一個叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的編碼是FEFF。而FFFE在UCS中是不存在的字符,所以不應該出現(xiàn)在實際傳輸中。UCS規(guī)范建議我們在傳輸字節(jié)流前,先傳輸字符"ZERO WIDTH NO-BREAK SPACE"。這樣如果接收者收到FEFF,就表明這個字節(jié)流是Big-Endian的;如果收到FFFE,就表明這個字節(jié)流是Little-Endian的。因此字符"ZERO WIDTH NO-BREAK SPACE"又被稱作BOM。
UTF-8不需要BOM來表明字節(jié)順序,但可以用BOM來表明編碼方式。字符"ZERO WIDTH NO-BREAK SPACE"的UTF-8編碼是EF BB BF。所以如果接收者收到以EF BB BF開頭的字節(jié)流,就知道這是UTF-8編碼了。
Windows就是使用BOM來標記文本文件的編碼方式的。
另外unicode網(wǎng)站的
FAQ-BOM
詳細介紹了BOM。官方的自然權威,不過是英文的,看起來比較費勁。
UTF-8編碼的文件中,BOM占三個字節(jié)。如果用記事本把一個文本文件另存為UTF-8編碼方式的話,用UE打開這個文件,切換到十六進制編輯狀態(tài)就可以看到開頭的FFFE了。這是個標識UTF-8編碼文件的好辦法,軟件通過BOM來識別這個文件是否是UTF-8編碼,很多軟件還要求讀入的文件必須帶BOM。可是,還是有很多軟件不能識別BOM。我在研究Firefox的時候就知道,在Firefox早期的版本里,擴展是不能有BOM的,不過Firefox 1.5以后的版本已經(jīng)開始支持BOM了?,F(xiàn)在又發(fā)現(xiàn),PHP也不支持BOM。
PHP在設計時就沒有考慮BOM的問題,也就是說他不會忽略UTF-8編碼的文件開頭BOM的那三個字符。由于必須在轉(zhuǎn)換->UTF-8轉(zhuǎn)ASCII,或者在另存為里選擇ASCII編碼。如果是DOS格式的行尾符,可以用記事本打開,點另存為,選ASCII編碼。如果包含中文字符的話,可以用UE的另存為功能,選擇“UTF-8 無 BOM”即可。請參考下面的圖片:根據(jù)Bo-Blog的wiki的說明:Editplus需要先另存為gb,再另存為UTF-8。不過這樣做要小心,所有GBK編碼中不包含的字符就會都丟了。如果有一些非中文的字符在文件里的話還是不要用這種辦法了。(從這一個小方面來看,UE——UltraEdite-32確實比Editplus好很多,Editplus太輕量級了)
另外我發(fā)現(xiàn)了一個辦法,就是利用Wordpress提供的文件編輯器。這個辦法不受限制,不需要去下載專門的編輯器,畢竟大家都在用Wordpress嘛。先在ftp里把要編輯的文件的寫入權限打開,然后進入Wordpress后臺->管理->文件編輯器,輸入要編輯文件的路徑,點編輯文件。在顯示出來的編輯界面中,你是看不到開頭的那三個字符的,不過沒關系,把光標定位在整個文件的第一個字符前,按一下Backspace鍵。OK了,點更新文件吧,在ftp里刷新一下,可以看到文件小了3字節(jié),大功告成。
以上是“如何解決php讀取csv文件后uft8 bom導致在頁面上顯示出現(xiàn)問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享文章:如何解決php讀取csv文件后uft8bom導致在頁面上顯示出現(xiàn)問題-創(chuàng)新互聯(lián)
分享路徑:http://jinyejixie.com/article22/dseccc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設計公司、軟件開發(fā)、App設計、全網(wǎng)營銷推廣、響應式網(wǎng)站、虛擬主機
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容