首頁 後端開發 php教程 解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的有关问题

解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的有关问题

Jun 13, 2016 am 10:47 AM
200 array bom vb

解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的问题

写道
其实这个问题很久之前遇到过, 应该是没解决, 当时的情况是openoffice打开正常而excel打开不正常, 后来也没解决了, 只能把编码转了.

这次又遇到这个问题了, 在网上一番寻找, 在一篇java的文章里找到了原因, 是由于输出的CSV文件中没有BOM.

什么是BOM?

在UCS 编码中有一个叫做”ZERO WIDTH NO-BREAK SPACE”的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输字符”ZERO WIDTH NO-BREAK SPACE”。这样如果接收者收到FEFF,就表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little- Endian的。因此字符”ZERO WIDTH NO-BREAK SPACE”又被称作BOM。
UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8编码是EF BB BF。所以如果接收者收到以EF BB BF开头的字节流,就知道这是UTF-8编码了。
Windows就是使用BOM来标记文本文件的编码方式的。

那么如何在PHP中输出BOM呢?

在所有内容输出之前

print(chr(0xEF).chr(0xBB).chr(0xBF));?
<?phpfunction writeCsvToFile($file,array $data){	$fp = fopen($file, 'w');		//Windows下使用BOM来标记文本文件的编码方式	fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF));		foreach ($data as $line) {		fputcsv($fp, $line);	}		fclose($fp);}$file = "./testcsv.csv";$data = array(	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),	array(1,'色色',12345,'vb200'),);writeCsvToFile($file,$data);
登入後複製
?
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1666
14
CakePHP 教程
1425
52
Laravel 教程
1325
25
PHP教程
1273
29
C# 教程
1252
24
vb屬於哪種程式語言 vb屬於哪種程式語言 Jul 05, 2023 pm 02:14 PM

vb屬於高階程式語言,是一種通用的基於物件的程式語言,是一種為結構化的、模組化的、物件導向的、包含協助開發環境的事件驅動為機制的視覺化程式設計語言,採用了直覺的圖形使用者介面設計,可以透過拖放控制項、設定屬性和編寫事件處理程序來開發應用程序,這種視覺化程式設計的方式,使得開發者可以直觀地進行介面設計和編程,無需太多的編碼經驗。

使用C#中的Array.Sort函數對陣列進行排序 使用C#中的Array.Sort函數對陣列進行排序 Nov 18, 2023 am 10:37 AM

標題:C#中使用Array.Sort函數對陣列進行排序的範例正文:在C#中,陣列是一種常用的資料結構,經常需要對陣列進行排序運算。 C#提供了Array類,其中有Sort方法可以方便地對陣列進行排序。本文將示範如何使用C#中的Array.Sort函數對陣列進行排序,並提供具體的程式碼範例。首先,我們要先了解Array.Sort函數的基本用法。 Array.So

簡單明了的PHP array_merge_recursive()函式使用方法 簡單明了的PHP array_merge_recursive()函式使用方法 Jun 27, 2023 pm 01:48 PM

在進行PHP編程時,我們常常需要將數組合併。 PHP提供了array_merge()函數來完成數組合併的工作,但是當數組中存在相同的鍵時,函數會覆寫原來的值。為了解決這個問題,PHP在語言中還提供了一個array_merge_recursive()函數,該函數可以合併數組並保留相同鍵的值,使得程式的設計變得更加靈活。 array_merge

dom和bom物件有哪些 dom和bom物件有哪些 Nov 13, 2023 am 10:52 AM

dom和bom物件有:1、「document」、「element」、「Node」、「Event」和「Window」等5種DOM物件;2、「window」、「navigator」、「location」、「history」和「screen」等5種BOM物件。

如何使用PHP中的array_combine函數將兩個陣列拼成關聯數組 如何使用PHP中的array_combine函數將兩個陣列拼成關聯數組 Jun 26, 2023 pm 01:41 PM

在PHP中,有許多強大的陣列函數可以讓陣列的操作更加方便和快速。當我們需要將兩個陣列拼成一個關聯數組時,可以使用PHP的array_combine函數來實現這一操作。這個函數其實是用來將一個陣列的鍵當作另一個陣列的值,合併成一個新的關聯數組。接下來,我們將會講解如何使用PHP中的array_combine函數將兩個陣列拼成關聯數組。了解array_comb

bom和dom有什麼差別 bom和dom有什麼差別 Nov 13, 2023 pm 03:23 PM

bom和dom在作用和功能、與JavaScript的關係、相互依賴性、不同瀏覽器的兼容性和安全性考量等方面都有區別。詳細介紹:1、作用和功能,BOM的主要作用是操作瀏覽器窗口,它提供了瀏覽器窗口的直接訪問和控制,而DOM的主要作用則是將網頁文檔轉換為一個對象樹,允許開發者透過這個物件樹來取得和修改網頁的元素和內容;2、與JavaScript的關係等等。

vb中int是什麼意思 vb中int是什麼意思 Dec 03, 2020 am 09:48 AM

vb中int是指取整數的函數,其語法如“int(x)”,表示取不大於x的最大整數;和int函數功能類似的函數還有Fix函數,該函數會刪除小數部分而返回剩下下的整數。

探究PHP bom的涵義與作用 探究PHP bom的涵義與作用 Mar 10, 2024 pm 10:45 PM

PHPbom的意義和作用在PHP程式設計中,BOM(ByteOrderMark)是一種特殊的字元序列,用來標識檔案的編碼方式和位元組順序。 BOM通常是在檔案開頭的位置插入的,以便讓解析器識別編碼方式,特別是對於一些不以ASCII編碼開始的編碼格式,例如UTF-8。 BOM在不同的編碼格式下有不同的作用,以下將具體探究PHP中BOM的意義和作用,並結合程式碼範例加

See all articles