Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

Hallo zusammen,

ich erstelle mit folgender Funktion ein Excel Spreadsheet:


/**
* Exportiert eine MySQL Tabelle ins Excel format und sendet die Datei zum Browser
* @param string $location Speicherort auf dem Server
* @param string $filename Dateiname mit dem die Datei zum Download angeboten wird
* @param mysql_result $mysql_result Resultobject von mysql_query
*/
function rs2xls( $location, $filename, $mysql_result)
{
$filename = str_replace( ' ', '_', $filename);
$filename = str_replace( 'ä', 'ae', $filename);
$filename = str_replace( 'ö', 'oe', $filename);
$filename = str_replace( 'ü', 'ue', $filename);
$filename = str_replace( 'Ä', 'Ae', $filename);
$filename = str_replace( 'Ö', 'Oe', $filename);
$filename = str_replace( 'Ü', 'Ue', $filename);

$xls =& new Spreadsheet_Excel_Writer( $location);

// Send HTTP headers to tell the browser what's coming
handleError( $xls->send( $filename));

// Arbeitsblatt hinzufügen
handleError( $sheet =& $xls->addWorksheet( 'Tabelle1'));

$printHeaders = true;
$line = 0;
while(( $row = mysql_fetch_row( $mysql_result) )!== false) {
if ( $printHeaders) {
for ( $i = 0; $i < count( $row); $i++) {
$column = ucwords( mysql_field_name( $mysql_result, $i));
handleError( $sheet->write( $line, $i, $column));
}
$line++;
$printHeaders = false;
}

for ( $i = 0; $i < count( $row); $i++) {
handleError( $sheet->write( $line, $i, $row[ $i]));
}
$line++;
}

handleError( $xls->close());

return $filename;
}

function handleError( $obj) {
if (PEAR::isError($obj)) {
exit($obj->getMessage());
}
}
[/PHP]

Ich generiere damit eine Excel Datei auf dem Server und sende diese an den Client.

Die generierte Datei auf dem Server sieht genauso aus wie ich das haben will, aber leider bekommt der Client diese nicht "richtig" zum Download. Heisst also der Client bekommt eine andere Datei angeboten, als die die generiert wird...

Fehler gibt der Spreadsheet Writer keine aus, da diese ja ausgegeben in den Files stehen müsste, die auf dem Server generiert wurden...

Ich rufe die funktion so auf:

[PHP]
$result = mysql_query('SELECT * FROM tabelle');

rx2xls( "../files/rex_formbkk_kontakt/20050705_1725.xls",
"20050705_1725.xls",
$result);

Ich weiss langsam net mehr wo ich kucken soll :-(

Bin dankbar für jeden Tipp!

Gruß,

Markus

Geschrieben

Hi,

Wo und wie wird die Datei denn geschickt?


handleError( $xls->send( $filename)); // senden der header
//snip
handleError( $xls->close()); // senden der Datei
[/PHP]

Danke für die Mühe,

Gruß,

Markus

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...