AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein FreePascal Schleifenproblem in Lazarus
Thema durchsuchen
Ansicht
Themen-Optionen

Schleifenproblem in Lazarus

Ein Thema von ONeill · begonnen am 19. Mär 2013 · letzter Beitrag vom 25. Mär 2013
 
ONeill

Registriert seit: 17. Nov 2011
28 Beiträge
 
#1

Schleifenproblem in Lazarus

  Alt 19. Mär 2013, 14:32
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
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:10 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz