2012-06-18 3 views
0

CSV 형식으로 내보내려고합니다.하지만 사용하는 상호 호스트가 mysql에서 FILE 함수를 비활성화했습니다.MYSQL FILE 함수없이 CSV 내보내기

간단한 SELECT를 한 다음 PHP로 fopen 및 fwrite를 수행했습니다.

문제는 필드에 캐리지 리턴이나 큰 따옴표가 있다는 것입니다.

어떻게 유지하고 올바른 CSV 파일을 만드시겠습니까?

고마워요.

+0

호스트가 비활성화하지 않은 경우 'fputcsv' 기능이 있습니다. - http://php.net/manual/en/function.fputcsv.php – andrewsi

답변

0

. 당신은 다음과 같은 방법으로 할 수 있습니다. 당신이 html 코드를 가지고 설명을 동봉 만든다 +, 당신은 큰 따옴표를 사용해야합니다

$filename ='data.csv'; 
    $csv_terminated = "\n"; 
    $csv_separator = ","; 
    $csv_enclosed = '"'; 
    $csv_escaped = "\\"; 

$results = array('1','2','3');// value 

    $schema_insert = ''; 

    $header = array('a','b','c');// header 


    for ($i = 0; $i< count($header); $i++) 
    { 
     $l = $csv_enclosed . str_replace($csv_enclosed, $csv_escaped . $csv_enclosed, 
      stripslashes($header[$i])) . $csv_enclosed; 
     $schema_insert .= $l; 
     $schema_insert .= $csv_separator; 
    } // end for 

    $out = trim(substr($schema_insert, 0, -1)); 
    $out .= $csv_terminated; 

    // Format the data 
    for($i=0;$i<count($results);$i++) 
    { 
     $row = $results[$i]; 
     $schema_insert = ''; 
     for ($j = 0; $j < count($header); $j++) 
     { 
      if ($row[$j] == '0' || $row[$j] != '') 
      { 

       if ($csv_enclosed == '') 
       { 
        $schema_insert .= $row[$j]; 
       } else 
       { 
        $schema_insert .= $csv_enclosed . 
        str_replace($csv_enclosed, $csv_escaped . $csv_enclosed, $row[$j]) . $csv_enclosed; 
       } 
      } else 
      { 
       $schema_insert .= 'NULL'; 
      } 

      if ($j < count($header) - 1) 
      { 
       $schema_insert .= $csv_separator; 
      } 
     } // end for 

     $out .= $schema_insert; 
     $out .= $csv_terminated; 
    } // end while 

    header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); 
    header("Content-Length: " . strlen($out)); 
    // Output to browser with appropriate mime type, you choose <img src="http://thetechnofreak.com/wp-includes/images/smilies/icon_wink.gif" alt=";)" class="wp-smiley"> 
    header("Content-type: text/x-csv"); 
    //header("Content-type: text/csv"); 
    //header("Content-type: application/csv"); 
    header("Content-Disposition: attachment; filename=$filename"); 
    echo $out; 

알 수 있습니다. + 빈 값 -> Null 텍스트 또는 0 값으로 변경

CSV가 향상됩니다.

+1

안녕하세요. "스팸"으로 응답에 태그를 지정하지 마십시오. 그것은 싫은 내색이다. 이 주제에 관해서도 [이 게시물] (http://meta.stackexchange.com/questions/5029/are-taglines-signatures-disallowed)을 읽으십시오. 여기에 더 머물 수 있습니다. – PeeHaa

0

당신은 예를 들어, 사용 헤더() 헤더 기능 후 원하는

출력 모든 (CSV 형식에 대한 기본)에 의해 file.csv 다운로드 할 수 있습니다 최고의 CSV를 구축하기 위해

$filename = "output"; 
    header('Content-Type: text/csv'); 
    header('Content-disposition: attachment;'.$filename.'=.csv'); 

    $separate = ","; //or ; 
    $endline = "\r\n"; 
    foreach($data as $key => $item) 
    { 
     echo $key.$separate.$value.$endline; 
    } 
0
protected function getCsv($fileName, array $data) 
    { 
     // alot of headers here, make force download work on IE8 over SSL 
     header("Pragma: public"); 
     header("Expires: 0"); 
     header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); 
     header("Cache-Control: private",false); 
     header("Content-Type: application/octet-stream"); 
     header('Content-Disposition: attachment; filename="'.$fileName.'"'); 
     header("Content-Transfer-Encoding: binary"); 

     // Joe Green says: 
     // based on http://www.php.net/manual/en/function.fputcsv.php#100033 

     $outStream = fopen("php://output", "r+"); 
     function __getCsv(&$vals, $key, $filehandler) { 
      fputcsv($filehandler, $vals, ',', '"'); 
     } 
     array_walk($data, '__getCsv', $outStream); 
     fclose($outStream); 
    } 

fputcsv은 (는) 친구입니다. 또한,이 시점까지이 기능을 수정해야했습니다. 이러한 헤더 중 일부는 IE에서 csv를 CSV, 특히 SSL을 통해 강제로 열도록 요구합니다. 나는 IE8이 첫 번째 인스턴스에서 'text/csv'콘텐츠 유형을 인식하지 못하고 두 번째 인스턴스에서 SSL 다운로드와 관련된 일부 보안 기능을 인식하지 못한다는 것을 상기 한 것 같습니다.