>php教程 >php手册 >(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常

(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常

WBOY
WBOY원래의
2016-06-06 19:55:481375검색

http://blog.csdn.net/thefirstwind/archive/2008/05/09/2422715.aspx 很多人通过拼字符串,直接使用fwrite来写CSV文件,这样固然没有错,但是如果遇到允许引号和逗号出现的情况,恐怕就显得非常麻烦了。 例如: $csvDate = 中文,日文,韩文,西班牙','文,阿拉

http://blog.csdn.net/thefirstwind/archive/2008/05/09/2422715.aspx

很多人通过拼字符串,直接使用fwrite来写CSV文件,这样固然没有错,但是如果遇到允许引号和逗号出现的情况,恐怕就显得非常麻烦了。

例如:
$csvDate = "中文,日文,韩文,西班牙','文,阿拉伯文";
$srcDir = '/workspace/CSVList';
$srcFile = $srcDir.date("Ymd").".csv";
if(!is_dir($srcDir)){
    $fh = fopen($srcFile,'wb');
    fwrite($fh,$csvDate);
    fclose($fh);
}

我们想要得CSV文件是这样的格式

中文 日文 韩文 西班牙','文 阿拉伯文  

但是由于,西班牙文中有单引号和逗号
实际上在Excel中是这样的
中文 日文 韩文 西班牙' 阿拉伯文

解决方法一般来说就是使用转义符来进行赋值,不过如果遇到海量数据的情况下,这样的办法是不可取的。
下面推荐使用array_push和fputcsv相结合的方法来解决该问题。

这里通过程序来说明:

(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常$srcDir = '/workspace/UnLockList/';
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
!is_dir($srcDir) ) && (mkdir($srcDir, 0777&& chmod($srcDir,0777)) ;
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
$srcFile = $srcDir . date("Ymd". '.csv';
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
$rs0 = GetCSVData($PRDBConn);  //UnLockTN_Request返回的是二维数组
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
$fh = fopen($srcFile, 'wb');
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
if(count($rs0)){
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常        fputcsv(
$fh,split(',',"申請ID,機種名,EB-№,申請№,部品名,LockUser"));
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常        
foreach($rs0 as $line0 ){
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常                fputcsv(
$fh,$line0);
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常        }
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常}
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常fputcsv(
$fh,array());
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
fclose($fh);
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常
chmod($srcFile,0666);

 function GetCSVData ($PRDBConn){

      $RETURN_ARRAY = array();
      //数据库连接
   .....
   .....

  $RS01 = 记录集;
      foreach ($RS01 AS $ROW01){
      $line = array();
         array_push($line,$ROW01["ID"]);
         array_push($line,$ROW01["NAME"]);
         array_push($line,$ROW01["NO"]);
         .......
         array_push($RETURN_ARRAY,$line);
       }

         return $RETURN_ARRAY; 
   }
(PHP)海量数据输出CSV文件时由于特殊字符引起的CSV文件格式异常


如上程序所示,就可以解决大量数据输出成CSV文件中,出现特殊意义字符,导致输出CSV文件格式异常的问题了。

 

 

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.