2012-06-18 36 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

要建立一個最好的CSV。你可以按照下面的方式做。

$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; 

注意, +當你封閉了具有HTML代碼描述,你應該使用雙引號。 +空值 - >更改爲空文字或零值

它們將使您的CSV更好。

+1

Hiya歡迎SO。請停止使用「垃圾郵件」標記您的答案。它皺起眉頭。有關此主題,請閱讀[此帖子](http://meta.stackexchange.com/questions/5029/are-taglines-signatures-disallowed)。享受您的進一步留在這裏。 – PeeHaa

0

您可以用頭()函數頭後,你想

輸出的一切(基地csv格式),例如下載FILE.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下載的安全特性。