日期:2014-05-16  浏览次数:20586 次

linux环境下PHP无法读取CSV文件中文字的解决方法

在win下可以轻松读取中文,但是放到linux的测试机器上,中文字就读取不出来。问题原因肯定和编码有关系:

	public function readCsv($file) {
		$row = 1; 
		if (!is_file($file)) {
			return array();
		}
		$handle = fopen($file,"r");
		$arr = array();
		while ($data = fgetcsv($handle, 1000, ",")) {  
			$num = count($data); 
			$row++;  
			for ($c=0; $c < $num; $c++) {
				$arr[$row]['book_id'] 			= $data[0];  
				$arr[$row]['book_title'] 		= iconv('gb2312', 'utf-8',$data[1]);  
				$arr[$row]['book_author'] 		= iconv('gb2312', 'utf-8',$data[2]);  
				$arr[$row]['book_img'] 			= $data[3];  
				$arr[$row]['book_taobao_price'] = $data[4];  
				$arr[$row]['book_des'] 			= iconv('gb2312', 'utf-8',$data[5]);  
			} 
		}
		$temp = array(); 
		foreach ($arr as $val) {
			if ($val['book_id'] != '' && is_numeric($val['book_id'])) {
				$temp[] = $val;
			}
		}
		fclose($handle);
		return $temp; 
	}


解决方法:setlocale

setlocale() 函数设置地区信息(地域信息)。

地区信息是针对一个地理区域的语言、货币、时间以及其他信息。

该函数返回当前的地区设置,若失败则返回 false。

 

setlocale(LC_ALL, 'zh_CN');