AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TList

Ein Thema von semo · begonnen am 21. Aug 2004 · letzter Beitrag vom 21. Aug 2004
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#1

TList

  Alt 21. Aug 2004, 19:25
ich habe folgendes Problem: ich importiere aus Excel eine Liste an Daten folgendermaßen:

1. lese jede Zeile ein und packe die Inhalte in eine StringList
2. die StringListe packe ich in eine TList
3. die TList will ich dann auslesen

dabei tritt dann bei fehler bei folgender zuweisung auf:
ExcelZeile := TStringList(Schilder.Items[0]);

Was mache ich falsch?


hier der Quelltext:
Code:
private
  { Private-Deklarationen }
    ExcelZeile: TStringList;
    Schilder: TList;
...


procedure TMainForm.ButtonExcelImportClick(Sender: TObject);
var
  schildZeile: TLabel;
  i: Integer;
begin
  OpenDialog.Filter := 'Excel Tabelle(*.xls)|*.xls';
  if OpenDialog.Execute then
  begin
    Schilder  := TList.Create;

    // Excelzeilen einlesen
    ladeZeilen(OpenDialog.Filename);

    ShowMessage(IntToStr(Schilder.Count) + ' Zeilen aus der Excel Tabelle eingelesen');

    // die Zeilen des ersten Schildes anzeigen
    ExcelZeile := TStringList(Schilder.Items[0]);
    ShowMessage('Anzahl der Felder in der StringList:' + #13#10 +
                IntToStr(ExcelZeile.Count));
    for i:=0 to ExcelZeile.Count-1 do
    begin
      schildZeile := TLabel.Create(Gravurflaeche);
      with schildZeile do
      begin
        Parent := Gravurflaeche;
        Visible := true;
        Left   := 10;
        Top    := i*14 + 10;
        Text   := ExcelZeile.ValueFromIndex[i];
        ShowMessage(ExcelZeile.ValueFromIndex[i]);
        Name   := 'Label' + IntToStr(i);
      end;
    end;
    ExcelZeile.Free;
  end;
end;
  Mit Zitat antworten Zitat
paelesoft

Registriert seit: 3. Jul 2004
37 Beiträge
 
Delphi 7 Professional
 
#2

Re: TList

  Alt 21. Aug 2004, 19:28
Zitat von computer-glossar.de:
dabei tritt dann bei fehler bei folgender zuweisung auf:
Wie heißt der Fehler? (index oder so?)
Gruß Erik
  Mit Zitat antworten Zitat
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#3

Re: TList

  Alt 21. Aug 2004, 19:31
zugriffsverletzung
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#4

Re: TList

  Alt 21. Aug 2004, 19:32
Hast du die Stringliste auch irgendwo erzeugt?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#5

Re: TList

  Alt 21. Aug 2004, 19:38
mache ich doch mit dieser anweisung:

Code:
ExcelZeile := TStringList(Schilder.Items[0]);
  Mit Zitat antworten Zitat
Kernel32.DLL
(Gast)

n/a Beiträge
 
#6

Re: TList

  Alt 21. Aug 2004, 20:24
erzeugt man 'ne Stringlist nicht normalerweise mit:

Delphi-Quellcode:
var
Stringlist: TStringlist;

[...]

Stringlist := TStringlist.create;
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#7

Re: TList

  Alt 21. Aug 2004, 20:33
Zeig uns doch bitte mal die Prozedur LadeZeilen. Denn dort wird (hoffentlich) Schilder gefüllt, was für das Verständnis notwendig ist.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#8

Re: TList

  Alt 21. Aug 2004, 20:42
Code:
procedure TMainForm.ladeZeilen(excelFilename: String);
var
  myExcel, Sheet: OLEVariant;
  zeile, spalte, lastRow: Integer;
  index: Integer;
  tempStringList: TStringList;
begin
  if excelFilename <> '' then
  begin
    try
      // Create Excel-OLE Object
      myExcel := CreateOleObject('Excel.Application')
    except
      ShowMessage('Excel konnte nicht gestartet werden!');
      exit
    end;

    // Excel verbergen
    myExcel.Visible := false;

    // Öffnen der gewählten Arbeitsmappe
    myExcel.Workbooks.Open(excelFilename);

     Sheet := myExcel.Workbooks[1].WorkSheets[1];
    //Sheet := myExcel.Workbooks[ExtractFileName(excelFilename)].WorkSheets[1];

    // die letzte nicht leere Zelle aktivieren
    Sheet.Cells.SpecialCells(xlCellTypeLastCell, EmptyParam).Activate;

    // ich muss jede Zeile einlesen und jede Zeile kann unterschiedlich viel Spalten haben
    // von 1 bis lastRow eine For-Schleife durchlaufen
    // lastCol pro Zeile in der Schleife ermitteln
    // --> die einzelnen Zellinhalt in ein Array packen
    // --> das Array (entspricht dem kompletten Inhalt einer Zeile) in eine Liste packen
    lastRow := myExcel.ActiveCell.Row;

    tempStringList := TStringList.Create;
    for zeile := 1 to lastRow do
    begin
      spalte := 1;
      tempStringList.Clear;
      while (myExcel.Cells[zeile, spalte].Value <> '') do
      begin
        //SetLength(ArrOfZeilen, spalte); // Arraylänge erhöhen
        //ArrOfZeilen[spalte-1] := myExcel.Cells[zeile, spalte].Value;
        index := tempStringList.Add(myExcel.Cells[zeile, spalte].Value);
        {ShowMessage('Zeile: ' + IntToStr(zeile) + #13#10 +
                    'Spalte: ' + IntToStr(spalte) + #13#10 +
                    'Value: ' + myExcel.Cells[zeile, spalte].Value + #13#10 +
                    'index in Excelzeile: ' + IntToStr(index));
        }
        Inc(spalte);
      end;
      Schilder.Add(tempStringList);
      Caption := IntToStr(Schilder.Count);
    end;

    // Quit Excel
    if not VarIsEmpty(myExcel) then
    begin
      myExcel.DisplayAlerts := False;
      myExcel.Quit;
      myExcel := Unassigned;
      Sheet  := Unassigned;
    end ;
    tempStringList.Free
  end;
end;
  Mit Zitat antworten Zitat
Kernel32.DLL
(Gast)

n/a Beiträge
 
#9

Re: TList

  Alt 21. Aug 2004, 20:48
Also, ihr könnt mich ja für blöde erklären, aber mein:

Code:
ExcelZeile := TStringList.Create;
habe ich immer noch nicht gefunden!

Das brauch' man doch, oder?

*Weltanschauung durcheinander werf*
  Mit Zitat antworten Zitat
Benutzerbild von semo
semo

Registriert seit: 24. Apr 2004
755 Beiträge
 
Delphi 2010 Professional
 
#10

Re: TList

  Alt 21. Aug 2004, 20:53
ich habe das mal so gelernt dass man die ein Objekt erzeugen kann wenn man das Item einer TList unter Angabe des Objekttypes zuweist, sind ja nur pointer die da zugewiesen werden

stringListe := TStringList(List.Items[0]);


folgendes bringt mich nämlich auch nicht weiter:
Code:
ExcelZeile := TStringList.Create;
// die Zeilen des ersten Schildes anzeigen
ExcelZeile := Schilder.Items[0];
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 10:31 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz