萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> 解決PHP導出CSV文中文亂碼問題

解決PHP導出CSV文中文亂碼問題

   csv文件可以使用excel打開並進行一些操作了,同時我們用php導入csv文件是非常的簡單了,所以我們通常會使用php來導出csv了,但有時會碰到在使用Excel打開csv時出現亂碼問題了,下面我們就來看解決辦法。

  亂碼情況

  寫了一段導出 CSV 文件的代碼,可以正常輸出

  使用 CSV 和 TXT 程序打開文件是正常的,但是使用 Excel 打開文件就出現了中文亂碼的問題(這就奇怪了, 為什麼在 Excel 中會亂碼呢?)

  通過查看編碼發現,導出的 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);

  }

  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);//轉換編碼

  if(fwrite($handle,$strUsersData)==false){}

  fclose($handle);

  down_file($fname,'555.csv');

copyright © 萬盛學電腦網 all rights reserved