AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

csv-Datei einlesen

Ein Thema von Hänsel · begonnen am 10. Jun 2019 · letzter Beitrag vom 11. Jun 2019
Antwort Antwort
Hänsel

Registriert seit: 4. Okt 2018
7 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#1

csv-Datei einlesen

  Alt 10. Jun 2019, 16:17
Hallo kann mir bei meinen Problem jemand helfen?

Ich habe zum Einlesen einer csv-Dateien folgenden Code geschrieben:
procedure TForm1.Import1FromCSVfile(sFile: string);
var
tfDatei: TextFile;
sZInhalt,be: string;
slWerte: TStringList;
iZeile,zähler: Integer;
begin
Try
Try
AssignFile(tfDatei, sFile);
Reset(tfDatei);
iZeile:= 0;
while not EoF(tfDatei) do
begin
slWerte := TStringList.Create;
Readln(tfDatei,sZInhalt);

slWerte.Delimiter := ';';
slWerte.QuoteChar := '"';
slWerte.DelimitedText := sZInhalt;
Inc(iZeile); // erste Zeile ist der Kopf

tblImport.Open;
tblImport.Last;
tblImport.Append;
tblImport['OBJ'] :=Edit1.Text;
tblImport['Feld_01'] := slWerte.Strings[0];
tblImport['Feld_02'] := slWerte.Strings[1];
tblImport['Feld_03'] := slWerte.Strings[2];
tblImport['Feld_04'] := slWerte.Strings[3];

usw.

Es tritt folgendes Problem auf: Es werden alle Zeilen eingelesen.Aber wenn z.B. das erste Feld ein Text ist, welches aus zei Wörtern besteht, wird das erste Wort in die erste Spalte geschrieben und das zweite Wort (welches eigendlich in die erste Zeile hehöhrt) in die zweite Spalte geschrieben. Dies geschieht bei allen Texten welche ein Leerzeichen haben. Dadurch verschiebt sich die Einlesung unkontrolliert.
Was habe ich da falsch gemacht bzw. was fehlt noch?
  Mit Zitat antworten Zitat
peterbelow

Registriert seit: 12. Jan 2019
Ort: Hessen
703 Beiträge
 
Delphi 12 Athens
 
#2

AW: csv-Datei einlesen

  Alt 10. Jun 2019, 16:53
sWerte.StrictDelimiter := true; Du solltest übrigens lieber die Datei per TStreamReader lesen, nicht über das uralte Textfile-"API". Dadurch kannst Du auch mit anderen Zeichenkodierunge fertig werden.
Peter Below

Geändert von TBx (10. Jun 2019 um 23:28 Uhr) Grund: Fullquote entfernt
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#3

AW: csv-Datei einlesen

  Alt 10. Jun 2019, 22:44
Such mal nach csv da ist der zweite Eintrag https://www.delphipraxis.net/164041-...ntdataset.html. Darin findest Du einen Lösung und noch Links zu ähnlichen Lösungen.


Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Hänsel

Registriert seit: 4. Okt 2018
7 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#4

AW: csv-Datei einlesen

  Alt 11. Jun 2019, 06:49
Hallo
ich bedanke mich für die guten Hinweise. Habe es ausprobiert, alles o.k.

Danke nochmals
Hänsel
  Mit Zitat antworten Zitat
Blackpit

Registriert seit: 27. Feb 2019
77 Beiträge
 
#5

AW: csv-Datei einlesen

  Alt 11. Jun 2019, 19:26
@Hänsel
Nur Interessehalber, welche Version hast du genommen?
  Mit Zitat antworten Zitat
Alt 11. Jun 2019, 21:32     Erstellt von Luckie
Dieser Beitrag wurde von Luckie gelöscht.
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 02:00 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