2016-07-08 1 views
0

habe ich die Datei PHPExcel zu sagen C:\path\goes\here\filename.xls mit Wenn ich versuche, darauf zuzugreifen header(), mit es erstellt eine Datei filename(1), filename(2) und so weiter. (PS: Wenn ich Override sage, möchte ich vorherigen Inhalt löschen und neue Daten hinzufügen).Kann ich eine Excel-Datei mit PHP überschreiben?

<?php 

include 'PHPExcel.php'; 

require_once ("C:\\xampp\\htdocs\\excel_mailer_2\\PHPMailer-master\\class.phpmailer.php"); 

$path   = "C:\\Users\\Manish\\Downloads"; 
$file_name  = $_GET['file_name']; 

$DB_server  = "localhost"; 
$DB_username = "root"; 
$DB_password = ""; 
$DB_dbname  = "timetracker"; 
$DB_tablename = "tt_users"; 

$conn   = mysqli_connect ($DB_server, $DB_username, $DB_password, $DB_dbname); 

if (mysqli_connect_errno()) { 
    die ("Connection Failed!"); 
} 

$sql = "SELECT *"; 
$sql .= " FROM $DB_tablename"; 

if ($result = mysqli_query($conn,$sql)); 

else die("Couldn't execute query:<br />" . mysqli_error(). "<br />" . mysqli_errno()); 

$file_ending = ".xls"; 

$filename = $file_name.$file_ending; 

//header("Content-Type: application/vnd.ms-excel"); 
header("Content-Disposition: attachment; filename=$filename"); 



/*******Start of Formatting for Excel*******/ 

$sep  = "\t"; 
$flag  = true; 
$col_names = ""; 

while($row = mysqli_fetch_assoc($result)) { 
    $data_insert = ""; 
      foreach($row as $field=>$data) { 
     if ($flag) 
      $col_names  .= $field.$sep; 
     if(!isset($data)) 
      $data_insert .= "NULL".$sep; 
     elseif ($data != "") 
      $data_insert .= $data.$sep; 
     else 
      $data_insert .= "".$sep; 
    } 

    if ($flag) { 
     $flag  = !$flag; 
     $col_names .= "\t"; 
     echo (trim($col_names)); 
     echo "\n"; 
    } 
    $data_insert .= "\t"; 
    echo (trim($data_insert)); 
    echo "\n"; 
} 
?> 
+0

Nichts mit PHPExcel oder mit PHP zu tun, dass Browser-Verhalten –

+0

@ Mark Baker, so dass Sie sagen, es ist nicht möglich? –

+0

Ich sage, dass, wenn Sie eine Datei an den Browser senden, dann ist es an den Browser selbst, oder der Client-Benutzer zu bestimmen, welchen Namen die Datei gespeichert wird, und der serverseitige Code kann nur einen Dateinamen "vorschlagen" –

Antwort

0

Hallo schreiben Sie Ihre filename in header Funktion mit diesem

header('Content-Disposition: attachment; filename="filename.xls"'); 
+0

ich habe das gemacht meine Frage bearbeitet und meinen Code freigegeben –

+0

haben Sie versucht zu sehen, was $ file_name hat ?? – user1234

+0

Ich habe den gewünschten Dateinamen über '$ file_name' aus' index.php' gesendet. –

Verwandte Themen