Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Galera, estou com um problema para conseguir fazer um export csv file de uma busca. Tenho uma base e quero filtrar por gênero quando ele der o resultado quero poder fazer um download só desses resultados por um arquivo csv.
Andei pesquisando na internet, mas como sou novo com PHP e MySQL não consigo ir em frente, tenho o csv funcionando mas ele pega todos os campos, e eu gostaria de pegar só o resultado que deu alguém pode me ajudar?
Segue o código que já tenho que gera o csv:
<?php
// Database Connection
$host="localhost";
$uname="root";
$pass="";
$database = "teste";
$filename = "export.csv";
$connection=mysql_connect($host,$uname,$pass);
echo mysql_error();
//or die("Database Connection Failed");
$selectdb=mysql_select_db($database) or
die("Database could not be selected");
$result=mysql_select_db($database)
or die("database cannot be selected <br>");
// Fetch Record from Database
$output = "";
$table = "contatos"; // Enter Your Table Name
$sql = mysql_query("select * from $table");
$columns_total = mysql_num_fields($sql);
// Get The Field Name
for ($i = 0; $i < $columns_total; $i++) {
$heading = mysql_field_name($sql, $i);
$output .= '"'.$heading.'",';
}
$output .="\n";
// Get Records from the table
while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$output .='"'.$row["$i"].'",';
}
$output .="\n";
}
// Download the file
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
echo $output;
exit;
?>
Alguém sabe como me ajudar? :( :(
Desde já agradeço.
>
E ai, vendo o código que você postou não achei o momento que você insere os dados de $out ao arquivo.
adicione esta linha e teste
if(is_writable($file_name)){ //Verifica a permissão do arquivo,
if(!( $file = fopen($filename, 'w')){
die('Não foi possível abrir o aquivo '.$filename);
}
if((fwrite($file, $output, strlen($output)))===FALSE){
die('Não foi possível escrever no aquivo '.$filename);
}
fclose($file)
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
}
Coloca no final do arquivo ou dentro $output ? :upset:
Coloca no final do arquivo ou dentro $output ? :upset:
depois de:
. . .
while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$output .='"'.$row["$i"].'",';
}
$output .="\n";
}
if(is_writable($file_name)){ //Verifica a permissão do arquivo.
if(!( $file = fopen($filename, 'w')){
die('Não foi possível abrir o aquivo '.$filename);
}
if((fwrite($file, $output, strlen($output)))===FALSE){
die('Não foi possível escrever no aquivo '.$filename);
} header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
}>
depois de:
. . .
while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$output .='"'.$row["$i"].'",';
}
$output .="\n";
}
if(is_writable($file_name)){ //Verifica a permissão do arquivo.
if(!( $file = fopen($filename, 'w')){
die('Não foi possível abrir o aquivo '.$filename);
}
if((fwrite($file, $output, strlen($output)))===FALSE){
die('Não foi possível escrever no aquivo '.$filename);
} header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
}
Ele da este erro:
Parse error: syntax error, unexpected '{' in /home/onwinfo/public_html/NewsTeste/novo/exporta_csv.php on line 46
>
Ele da este erro:
Parse error: syntax error, unexpected '{' in /home/onwinfo/public_html/NewsTeste/novo/exporta_csv.php on line 46
Faltou fechar uma chave e um ponto e virgula :)
if(is_writable($file_name)){ //Verifica a permissão do arquivo.
if(!( $file = fopen($filename, 'w'))){
die('Não foi possível abrir o aquivo '.$filename);
}die('Não foi possível escrever no aquivo '.$filename);
}
fclose($file);
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
}>
Faltou fechar uma chave e um ponto e virgula :)
if(is_writable($file_name)){ //Verifica a permissão do arquivo.
if(!( $file = fopen($filename, 'w'))){
die('Não foi possível abrir o aquivo '.$filename);
}die('Não foi possível escrever no aquivo '.$filename);
}
fclose($file);
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
}
Agora ele não faz mas o download, só exibe todos os dados do banco. :(
Agora ele não faz mas o download, só exibe todos os dados do banco. :(
Verifica se escreveu esses dados no arquivo .csv, se sim, os dados que estão sendo mostrandos na página é conteúdo deste arquivo.
Deve não estar fazendo download por causa do cabeçalho.
teste esse:
header('Content-Disposition: attachment; filename='.$filename);
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header("Content-Description: File Transfer");
header("Content-Length: " . filesize($filename));>
Verifica se escreveu esses dados no arquivo .csv, se sim, os dados que estão sendo mostrandos na página é conteúdo deste arquivo.
Deve não estar fazendo download por causa do cabeçalho.
teste esse:
header('Content-Disposition: attachment; filename='.$filename);
header("Content-Type: application/force-download");
header("Content-Type: application/octet-stream");
header("Content-Type: application/download");
header("Content-Description: File Transfer");
header("Content-Length: " . filesize($filename));
Ainda não funciona :/
o conteúdo está no arquivo?
E ai, vendo o código que você postou não achei o momento que você insere os dados de $out ao arquivo.
adicione esta linha e teste
if(is_writable($file_name)){ //Verifica a permissão do arquivo,
if(!( $file = fopen($filename, 'w')){
if((fwrite($file, $output, strlen($output)))===FALSE){