Generate CSV file in PHP

<?php
   
function query_to_csv($db_conn, $query, $filename, $attachment = false, $headers = true
) {
       
        if(
$attachment
) {
           
// send response headers to the browser
           
header( 'Content-Type: text/csv'
);
           
header( 'Content-Disposition: attachment;filename='.$filename
);
           
$fp = fopen('php://output', 'w'
);
        } else {
           
$fp = fopen($filename, 'w'
);
        }
       
       
$result = mysql_query($query, $db_conn) or die( mysql_error( $db_conn
) );
       
        if(
$headers
) {
           
// output header row (if at least one row exists)
           
$row = mysql_fetch_assoc($result
);
            if(
$row
) {
               
fputcsv($fp, array_keys($row
));
               
// reset pointer back to beginning
               
mysql_data_seek($result, 0
);
            }
        }
       
        while(
$row = mysql_fetch_assoc($result
)) {
           
fputcsv($fp, $row
);
        }
       
       
fclose($fp
);
    }

   
// Using the function
   
$sql = "SELECT * FROM table"
;
   
// $db_conn should be a valid db handle

    // output as an attachment
   
query_to_csv($db_conn, $sql, "test.csv", true
);

   
// output to file system
   
query_to_csv($db_conn, $sql, "test.csv", false
);
?>

Comments

Popular posts from this blog

Some mistakes to avoid while looking for a job

How Understanding Cloud Computing Saved a Million Dollars!

How to create test account in moneybookers.com