Hallo Leute,
ich glaube ich brauche mal wieder einen Denkanstoß. Und zwar habe ich folgenden Code:
Delphi-Quellcode:
//Dateinamen festlegen, die geöffnet werden soll
filename:=ExtractFilePath(ParamStr(0))+'tabelle.xls';
//Überprüfen ob Datei vorhanden
if fileexists(filename) <> True then
begin
//Fehlermeldung anzeigen
MessageDlg('Datei '+filename+' nicht gefunden.', mtError, mbOkCancel, 0);
Application.Terminate;
end;
//Excel-Inhalt einlesen
MyWorkbook.ReadFromFile(filename, sfExcel5);
//Erstes Arbeitsplatt der Excel Mappe öffnen
MyWorksheet := MyWorkbook.GetFirstWorksheet;
//Alle Zeilen der Excel-Liste durch gehen
for i:=1 to MyWorksheet.GetLastRowNumber do
begin
//INhalt in ListBox schreiben
lb.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 0));
lb2.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 1));
lb3.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 2));
end;
Da ich nun aber mehr als nur eine Excel-Tabelle in die Listboxen laden muss, dachte ich mir, das ich einfach die Variable filename zu nem array of string mache und eine Schleife um den Code rum baue. Raus kam dann dieser Code (alle Variablen sind richtig gesetzt
):
Delphi-Quellcode:
//Dateinamen festlegen, die geöffnet werden soll
filen[0]:=ExtractFilePath(ParamStr(0))+'tabelle.xls';
filen[1]:=ExtractFilePath(ParamStr(0))+'tabelle2.xls';
for view := 0 To High(filen) do
begin
//Überprüfen ob Datei vorhanden
if fileexists(filen[view]) <> True then
begin
//Fehlermeldung anzeigen
MessageDlg('Datei '+filen[view]+' nicht gefunden.', mtError, mbOkCancel, 0);
Application.Terminate;
end;
//Excel-Inhalt einlesen
MyWorkbook.ReadFromFile(filen[view], sfExcel5);
//Erstes Arbeitsplatt der Excel Mappe öffnen
MyWorksheet := MyWorkbook.GetFirstWorksheet;
//Alle Zeilen der Excel-Liste durch gehen
for i:=1 to MyWorksheet.GetLastRowNumber do
begin
//Inhalt in ListBox schreiben
lb.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 0));
lb2.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 1));
lb3.Items.Add(MyWorksheet.ReadAsUTF8Text(i, 2));
end;
end;
Leider kommt sofort eine
Exception beim EIntritt in die Schleife, ich kann allerdings keinen Fehler im Code feststellen, kann mir da ggf. einer einen Tipp geben? Das ist sicherlich weider irgendwas ganz einfaches
EDIT: Als
Exception-Klasse kommt immer: External:SIGSEGV
Grüße
Florian