AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Einlesen von alten Datensätze (Textdatei) in Datenbank
Thema durchsuchen
Ansicht
Themen-Optionen

Einlesen von alten Datensätze (Textdatei) in Datenbank

Ein Thema von Jens Hartmann · begonnen am 28. Sep 2009 · letzter Beitrag vom 4. Okt 2009
 
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#10

Re: Einlesen von alten Datensätze (Textdatei) in Datenbank

  Alt 3. Okt 2009, 18:36
Genau so mache ich das ja schon. Auswahl der Datein und das einlesen funktioniert ja auch, Beim Debuggen kann ich ja auch sehen, das alle Dateien gelesen werden.

ich zeig hier mal den gesamten Ablauf.

ORDNER wählen...

Delphi-Quellcode:
var
  Pfad : String;
begin
  SelectDirectory('Bitte Standort der Datenbank wählen', 'D:\Daten' ,Pfad);

  FindAllFiles(Pfad,'*.txt',True); //Verweis auf FindAllFiles Procedure
DATEIEN suchen und an PARSE Function übergeben

Delphi-Quellcode:
procedure FindAllFiles(RootFolder: string; Mask: string = '*.*'; Recurse: Boolean = True);
var
  SR: TSearchRec;
  Parser: TMySimpleBaseParser;
  FileStream: TFileStream;
  FileContents: TStringStream;
begin
  if RootFolder = 'then
    Exit;
  if AnsiLastChar(RootFolder)^ <> '\then
    RootFolder := RootFolder + '\';

  RootFolder := IncludeTrailingPathDelimiter(RootFolder);

  if Recurse then
    if
     FindFirst(RootFolder + '*.*', faAnyFile, SR) = 0 then
      try
        repeat
          if SR.Attr and faDirectory = faDirectory then

            if (SR.Name <> '.') and (SR.Name <> '..') then
              FindAllFiles(RootFolder + SR.Name, Mask, Recurse);
        until FindNext(SR) <> 0;
      finally
        FindClose(SR);
      end;
  if FindFirst(RootFolder + Mask, faAnyFile, SR) = 0 then
    try
      repeat
        if SR.Attr and faDirectory <> faDirectory then
        begin
          ImportForm.Memo1.Lines.Add(RootFolder + SR.Name); //Datein in Memo auflisten
          Parser := TMySimpleParserB.Create; //Parser erstellen
          ImportForm.DoParse(Parser, RootFolder + SR.Name); //aktuelle Datei Parsen lassen
          ImportForm.DisplayResult(Parser); //Aktuelle geparste Datei ausgeben
          Parser.Free;
        end;
      until FindNext(SR) <> 0;
    finally
      FindClose(SR);
    end;
end;
Geparste Datei ausgeben

Delphi-Quellcode:
procedure TImportForm.DisplayResult(Parser: TMySimpleBaseParser);
var
  i: Integer;
  ID : Integer;
  Daten : TOMBSerie;
begin
  ID := 1;
  ProgBarDatei.Max := High(Parser.EntriesMB256);
  VST.Clear;
  VST.BeginUpdate;
  for i := 0 to High(Parser.EntriesMB256) do begin
  Daten := TOMBSerie.Create;
  with Daten do
  begin
    Daten.ID := ID;
    Daten.LfdNr := Parser.EntriesMB256[i].LfdNr;
    Daten.Datum := Parser.EntriesMB256[i].Datum;
    Daten.Uhrzeit := Parser.EntriesMB256[i].Uhrzeit;
    Daten.Ereignis := Parser.EntriesMB256[i].Ereignis;
    Daten.Teilnehmer := Parser.EntriesMB256[i].Teilnehmer;
    Daten.Bereich := Parser.EntriesMB256[i].Bereich;
  end;
  VST.AddChild(nil, Daten);
  ProgBarDatei.Position := ID;
  Inc(ID);
  end;
  VST.ScrollIntoView(VST.GetLast, true);
  VST.EndUpdate;
end;
Und selbst bei DisplayResult, werden alle Dateien durchlaufen.

Mein Problem ist nur, das nicht alle Dateien, die die Function DosplayResult durchlaufen haben im VST dargestellt werden. Im Memo, kann man allerdings alle sehen.


MFG

Jens
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  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 06:00 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