PHP_XLSXWriter
PHP_XLSXWriter 0.39
Diese Bibliothek ist leichtgewichtig konzipiert und benötigt nur minimalen Speicher.
Es ist für die Ausgabe einer Excel-kompatiblen Tabelle im xlsx-Format (Office 2007+) konzipiert, wobei nur grundlegende Funktionen unterstützt werden:
Mit PHPExcel geht Ihnen nie wieder der Arbeitsspeicher aus.
Einfaches PHP-CLI-Beispiel:
$ data = array (
array ( ' year ' , ' month ' , ' amount ' ),
array ( ' 2003 ' , ' 1 ' , ' 220 ' ),
array ( ' 2003 ' , ' 2 ' , ' 153.5 ' ),
);
$ writer = new XLSXWriter ();
$ writer -> writeSheet ( $ data );
$ writer -> writeToFile ( ' output.xlsx ' );
Einfache/erweiterte Zellformate:
$ header = array (
' created ' => ' date ' ,
' product_id ' => ' integer ' ,
' quantity ' => ' #,##0 ' ,
' amount ' => ' price ' ,
' description ' => ' string ' ,
' tax ' => ' [$$-1009]#,##0.00;[RED]-[$$-1009]#,##0.00 ' ,
);
$ data = array (
array ( ' 2015-01-01 ' , 873 , 1 , ' 44.00 ' , ' misc ' , ' =D2*0.05 ' ),
array ( ' 2015-01-12 ' , 324 , 2 , ' 88.00 ' , ' none ' , ' =D3*0.05 ' ),
);
$ writer = new XLSXWriter ();
$ writer -> writeSheetHeader ( ' Sheet1 ' , $ header );
foreach ( $ data as $ row )
$ writer -> writeSheetRow ( ' Sheet1 ' , $ row );
$ writer -> writeToFile ( ' example.xlsx ' );
50.000 Zeilen: (1,4 s, 0 MB Speichernutzung)
include_once ( " xlsxwriter.class.php " );
$ writer = new XLSXWriter ();
$ writer -> writeSheetHeader ( ' Sheet1 ' , array ( ' c1 ' => ' integer ' , ' c2 ' => ' integer ' , ' c3 ' => ' integer ' , ' c4 ' => ' integer ' ) );
for ( $ i = 0 ; $ i < 50000 ; $ i ++)
{
$ writer -> writeSheetRow ( ' Sheet1 ' , array ( $ i , $ i + 1 , $ i + 2 , $ i + 3 ) );
}
$ writer -> writeToFile ( ' huge.xlsx ' );
echo ' # ' . floor (( memory_get_peak_usage ())/ 1024 / 1024 ). " MB " . "n" ;
Reihen | Zeit | Erinnerung |
---|---|---|
50000 | 1,4s | 0 MB |
100000 | 2,7s | 0 MB |
150000 | 4,1s | 0 MB |
200000 | 5,7s | 0 MB |
250000 | 7,0s | 0 MB |
Einfache Zellformate werden komplexeren Zellformaten zugeordnet
einfache Formate | Formatcode |
---|---|
Zeichenfolge | @ |
ganze Zahl | 0 |
Datum | JJJJ-MM-TT |
Datum/Uhrzeit | JJJJ-MM-TT HH:MM:SS |
Zeit | HH:MM:SS |
Preis | #,##0,00 |
Dollar | [$$-1009]#,##0,00;[ROT]-[$$-1009]#,##0,00 |
Euro | #,##0,00 [$€-407];[ROT]-#,##0,00 [$€-407] |
Grundlegende Zellstile sind seit Version 0.30 verfügbar
Stil | zulässige Werte |
---|---|
Schriftart | Arial, Times New Roman, Courier New, Comic Sans MS |
Schriftgröße | 8,9,10,11,12 ... |
Schriftstil | Fett, kursiv, unterstrichen, durchgestrichen oder mehrfach, z. B. „fett, kursiv“ |
Grenze | links, rechts, oben, unten oder mehrere, z. B. „oben, links“ |
Border-Stil | dünn, mittel, dick, dashDot, dashDotDot, gestrichelt, gepunktet, doppelt, Haar, mediumDashDot, mediumDashDotDot, mediumDashed, slantDashDot |
Randfarbe | #RRGGBB, also: #ff99cc oder #f9c |
Farbe | #RRGGBB, also: #ff99cc oder #f9c |
füllen | #RRGGBB, also: #eeffee oder #efe |
halign | Allgemein, links, rechts, ausrichten, zentrieren |
valign | unten, in der Mitte, verteilt |