# Tutorial 5 - Tabellen

## Erstellung einfacher Tabellen

Diese Anleitung zeigt eine einfache Art und Weise Tabellen zu erzeugen.

`<?phpdefine('FPDF_FONTPATH','font/');require('fpdf.php');class PDF extends FPDF{  // Load data  function LoadData({"\$"}file)  {    // Read file lines    {"\$"}lines=file({"\$"}file);    {"\$"}data=array();    foreach({"\$"}lines as {"\$"}line)     {"\$"}data[]=explode(';',chop({"\$"}line));    return {"\$"}data;  }  // Simple table  function BasicTable({"\$"}header,{"\$"}data)  {    // Header    foreach({"\$"}header as {"\$"}col)     {"\$"}this->Cell(40,7,{"\$"}col,1);    {"\$"}this->Ln();    // Data    foreach({"\$"}data as {"\$"}row)    {     foreach({"\$"}row as {"\$"}col)     {"\$"}this->Cell(40,6,{"\$"}col,1);     {"\$"}this->Ln();    }  }  // Better table  function ImprovedTable({"\$"}header,{"\$"}data)  {    // Column widths    {"\$"}w=array(40,35,40,45);    // Header    for({"\$"}i=0;{"\$"}i<count({"\$"}header);{"\$"}i++)     {"\$"}this->Cell({"\$"}w[{"\$"}i],7,{"\$"}header[{"\$"}i],1,0,'C');    {"\$"}this->Ln();    // Data    foreach({"\$"}data as {"\$"}row)    {     {"\$"}this->Cell({"\$"}w[0],6,{"\$"}row[0],'LR');     {"\$"}this->Cell({"\$"}w[1],6,{"\$"}row[1],'LR');     {"\$"}this->Cell({"\$"}w[2],6,number_format({"\$"}row[2]),'LR',0,'R');     {"\$"}this->Cell({"\$"}w[3],6,number_format({"\$"}row[3]),'LR',0,'R');     {"\$"}this->Ln();    }    // Closure line    {"\$"}this->Cell(array_sum({"\$"}w),0,'','T');  }  // Colored table  function FancyTable({"\$"}header,{"\$"}data)  {    // Colors, line width and bold font    {"\$"}this->SetFillColor(255,0,0);    {"\$"}this->SetTextColor(255);    {"\$"}this->SetDrawColor(128,0,0);    {"\$"}this->SetLineWidth(.3);    {"\$"}this->SetFont('','B');    // Header    {"\$"}w=array(40,35,40,45);    for({"\$"}i=0;{"\$"}i<count({"\$"}header);{"\$"}i++)     {"\$"}this->Cell({"\$"}w[{"\$"}i],7,{"\$"}header[{"\$"}i],1,0,'C',1);    {"\$"}this->Ln();    // Color and font restoration    {"\$"}this->SetFillColor(224,235,255);    {"\$"}this->SetTextColor(0);    {"\$"}this->SetFont('');    // Data    {"\$"}fill=0;    foreach({"\$"}data as {"\$"}row)    {     {"\$"}this->Cell({"\$"}w[0],6,{"\$"}row[0],'LR',0,'L',{"\$"}fill);     {"\$"}this->Cell({"\$"}w[1],6,{"\$"}row[1],'LR',0,'L',{"\$"}fill);     {"\$"}this->Cell({"\$"}w[2],6,number_format({"\$"}row[2]),'LR',0,'R',{"\$"}fill);     {"\$"}this->Cell({"\$"}w[3],6,number_format({"\$"}row[3]),'LR',0,'R',{"\$"}fill);     {"\$"}this->Ln();     {"\$"}fill=!{"\$"}fill;    }    {"\$"}this->Cell(array_sum({"\$"}w),0,'','T');  }}{"\$"}pdf=new PDF();// Column titles{"\$"}header=array('Country','Capital','Area (sq km)','Pop. (thousands)');// Data loading{"\$"}data={"\$"}pdf->LoadData('countries.txt');{"\$"}pdf->SetFont('Arial','',14);{"\$"}pdf->AddPage();{"\$"}pdf->BasicTable({"\$"}header,{"\$"}data);{"\$"}pdf->AddPage();{"\$"}pdf->ImprovedTable({"\$"}header,{"\$"}data);{"\$"}pdf->AddPage();{"\$"}pdf->FancyTable({"\$"}header,{"\$"}data);{"\$"}pdf->Output();?>`

Eine Tabelle ist nur eine Sammlung von Zellen und wird aus diesen gebaut. Das erste Beispiel zeigt den einfachsten Weg dieses zu erreichen und baut die Tabelle aus umrahmten Zellen. Alle Zellen haben die gleiche Größe und sind links ausgerichtet. Das Ergebnis ist ziemlich einfach, aber schnell zu erreichen.

Die zweite Tabelle wird in einer verbesserten Art und Weise erzeugt: jede Spalte hat ihre eigene Breite, Titel sind zentriert und Zahlenwerte rechts ausgerichtet. Des weiteren wurden die horizontalen Linien über den entsprechenden Parameter für den Rahmen der Method Cell() entfernt. In diesem Fall wird der Rahmen nur link (L) und recht (R) gezeichnet.

Letztendlich fehlen noch die horizontalen Linien die Tabellen abzuschließen. Hierfür gibt es zwei Möglichkeiten: Die Prüfung ob die letzte Zeile der Tabelle hinzugefügt wird und die entsprechende Apassung des Rahmen für link/rechts/unten (LRB), oder wie in diesem Beispiel das Zeichnen einer Linie wenn alle Zeilen hinzugefügt wurden.

Die dritte Tabelle ist der zweiten sehr ähnlich, jedoch werden hier zusätzlich Farben verwendet. Füllfarbe, Textfarbe und Linenfarbe können einfach festgelegt werden. Wechselnde Einfärbung der Zeilen wird dadurch erreicht, dass abwechselnd transparente und eingefärbte Zellen verwendet werden.

Zurück

Es ist ein Fehler aufgetreten

# Es ist ein Fehler aufgetreten

## Was ist das Problem?

Bei der Ausführung des Skriptes ist ein Fehler aufgetreten. Irgendetwas funktioniert nicht richtig.

## Wie kann ich das Problem lösen?

Öffnen Sie die aktuelle Log-Datei im Ordner `var/logs` bzw. `app/logs` und suchen Sie die zugehörige Fehlermeldung (normalerweise die letzte).

### Weitere Informationen

Die Skriptausführung wurde gestoppt, weil irgendetwas nicht korrekt funktioniert. Die eigentliche Fehlermeldung wird aus Sicherheitsgründen hinter dieser Meldung verborgen und findet sich in der aktuellen Log-Datei (siehe oben). Wenn Sie die Fehlermeldung nicht verstehen oder nicht wissen, wie das Problem zu beheben ist, durchsuchen Sie die Contao-FAQs oder besuchen Sie die Contao-Supportseite.