- 工信部備案號 滇ICP備05000110號-1
- 滇公安備案 滇53010302000111
- 增值電信業(yè)務(wù)經(jīng)營許可證 B1.B2-20181647、滇B1.B2-20190004
- 云南互聯(lián)網(wǎng)協(xié)會理事單位
- 安全聯(lián)盟認證網(wǎng)站身份V標(biāo)記
- 域名注冊服務(wù)機構(gòu)許可:滇D3-20230001
- 代理域名注冊服務(wù)機構(gòu):新網(wǎng)數(shù)碼
csv文件可以使用excel打開并進行一些操作了,同時我們用php導(dǎo)入csv文件是非常的簡單了,所以我們通常會使用php來導(dǎo)出csv了,但有時會碰到在使用Excel打開csv時出現(xiàn)亂碼問題了,下面我們就來看解決辦法.
亂碼情況
寫了一段導(dǎo)出 CSV 文件的代碼,可以正常輸出,使用 CSV 和 TXT 程序打開文件是正常的,但是使用 Excel 打開文件就出現(xiàn)了中文亂碼的問題(這就奇怪了,為什么在 Excel 中會亂碼呢?)
通過查看編碼發(fā)現(xiàn),導(dǎo)出的 CSV 文件是 UTF-8 無BOM編碼格式,而我們通常使用 UTF-8 編碼格式 都是有 BOM 的.
嘗試著添加了 BOM 之后,中文亂碼的問題有解決了。
添加 BOM 到 CSV 文件中
示例代碼:
$file = fopen($export_file_path, 'w');
fwrite($file, chr(0xEF).chr(0xBB).chr(0xBF)); // 添加 BOM
foreach ($contens as $content) {
fputcsv($file, $content);
} //phpfensi.com
fclose($file);
另一種解決辦法:
function down_file($filepath,$filename)
{
if(!file_exists($filepath))
{
echo "backup error ,download file no exist";
exit();
}
ob_end_clean();
header('Content-Type: application/download');
header("Content-type: text/csv");
header('Content-Disposition: attachment;filename="'.$filename.'"');
header("Content-Encoding: binary");
header("Content-Length:".filesize($filepath));
header("Pragma: no-cache");
header("Expires: 0");
readfile($filepath);
$e=ob_get_contents();
ob_end_clean();
}
$fname='usersdata.csv';
$handle=fopen($fname,'wb');
$strUsersData =iconv('utf-8','gb2312',$strUsersData);//轉(zhuǎn)換編碼
if(fwrite($handle,$strUsersData)==false){}
fclose($handle);
down_file($fname,'555.csv');
售前咨詢
售后咨詢
備案咨詢
二維碼
TOP