溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么解決在php中讀取csv時中文亂碼的問題

發(fā)布時間:2020-07-11 09:19:31 來源:億速云 閱讀:774 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關(guān)怎么解決在php中讀取csv時中文亂碼的問題,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

php讀取csv時中文亂碼的解決辦法:首先在導(dǎo)入csv的php腳本文件頭部加上相應(yīng)代碼;然后使用【$row】進(jìn)行轉(zhuǎn)義,將中文編碼讀取出來;最后使用一個【fgetcsv()】方法的替代函數(shù),防止php該函數(shù)自帶著一些bug即可。

php讀取csv時中文亂碼的解決辦法:

1、首先講linux,不管是centos或者Ubuntu。在導(dǎo)入csv的php腳本文件頭部加上如下代碼:

setlocale(LC_ALL,array('zh_CN.gbk','zh_CN.gb2312','zh_CN.gb18030'));

這段代碼的作用是改變腳本默認(rèn)編碼,因為操作系統(tǒng)的編碼格式不是GBK所以,讀取中文的時候會亂碼。

怎么解決在php中讀取csv時中文亂碼的問題

2、接著講windows,我們在讀取csv數(shù)據(jù)的時候,會有一個while循環(huán)遍歷每一行的數(shù)據(jù),而讀取的每一行數(shù)據(jù),就需要我們進(jìn)行轉(zhuǎn)義,將中文編碼讀取出來。代碼如下:

$row = eval('return '.iconv('gbk','utf-8',var_export($row,true)).';');

$row,就是讀取出來每一行的數(shù)據(jù)變量。

怎么解決在php中讀取csv時中文亂碼的問題

3、最后,貼一個fgetcsv()方法的替代函數(shù),這種是針對有些老版本的php該函數(shù)自帶著一些bug的情況。如果上邊兩點還是沒辦法解決您的問題,您可以嘗試一下使用該函數(shù),與前邊兩點配合使用。

function fgetcsv_reg(& $handle, $length = null, $d = ',', $e = '"') {
   $d = preg_quote($d);
   $e = preg_quote($e);
   $_line = "";
   $eof=false;
   while ($eof != true) {
       $_line .= (empty ($length) ? fgets($handle) : fgets($handle, $length));
       $itemcnt = preg_match_all('/' . $e . '/', $_line, $dummy);
       if ($itemcnt % 2 == 0)
           $eof = true;
   }
   $_csv_line = preg_replace('/(?: |[ ])?$/', $d, trim($_line));
   $_csv_pattern = '/(' . $e . '[^' . $e . ']*(?:' . $e . $e . '[^' . $e . ']*)*' . $e . '|[^' . $d . ']*)' . $d . '/';
   preg_match_all($_csv_pattern, $_csv_line, $_csv_matches);
   $_csv_data = $_csv_matches[1];
   for ($_csv_i = 0; $_csv_i < count($_csv_data); $_csv_i++) {
       $_csv_data[$_csv_i] = preg_replace('/^' . $e . '(.*)' . $e . '$/s', '$1', $_csv_data[$_csv_i]);
       $_csv_data[$_csv_i] = str_replace($e . $e, $e, $_csv_data[$_csv_i]);
   }
   return empty ($_line) ? false : $_csv_data;
}

怎么解決在php中讀取csv時中文亂碼的問題


以上就是怎么解決在php中讀取csv時中文亂碼的問題,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI