首頁 > 後端開發 > PHP問題 > php匯出mysql csv亂碼問題怎麼解決

php匯出mysql csv亂碼問題怎麼解決

藏色散人
發布: 2023-03-17 14:00:01
原創
1864 人瀏覽過

php匯出mysql csv亂碼問題的解決方法:1、開啟對應的php檔案;2、在檔案頭寫入BOM標識即可,程式碼如「fwrite($fp, chr(0xEF) . chr(0xBB) . chr(0xBF));」。

php匯出mysql csv亂碼問題怎麼解決

本教學操作環境:Windows7系統、PHP8.1版、Dell G3電腦。

php匯出mysql csv亂碼問題怎麼解決?

匯出csv在windows下開啟容易出現亂碼,需要在檔案頭寫入BOM標識,已經封裝成函數了

/**
 * @param array $rows
 * @param array $fields
 * @param string $filename
  */
  function kg_export_csv($rows, $fields = [], $filename = '')
  {
    $filename = $filename ?: kg_uniqid();
  
    header("Content-Type: text/csv");
    header("Content-Disposition:filename={$filename}.csv");
  
    $fp = fopen('php://output', 'w');
  
    fwrite($fp, chr(0xEF) . chr(0xBB) . chr(0xBF));
  
    if ($fields) fputcsv($fp, $fields);
  
    $index = 0;
  
    foreach ($rows as $row) {
     if ($index == 1000) {
     $index = 0;
     ob_flush();
     flush();
    }
    $index++;
    fputcsv($fp, $row);
  }
登入後複製

關鍵部分,檔案頭寫入BOM標識

fwrite($fp, chr(0xEF) . chr(0xBB) . chr(0xBF));
登入後複製

推薦學習:《PHP影片教學

以上是php匯出mysql csv亂碼問題怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板