AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Delphi CSV Dateien über OLE importieren, falsches Format in Feldern
Thema durchsuchen
Ansicht
Themen-Optionen

CSV Dateien über OLE importieren, falsches Format in Feldern

Ein Thema von ArneWolf · begonnen am 16. Jul 2008 · letzter Beitrag vom 17. Jul 2008
 
ArneWolf

Registriert seit: 6. Feb 2008
5 Beiträge
 
#6

Re: CSV Dateien über OLE importieren, falsches Format in Fel

  Alt 17. Jul 2008, 10:16
Hallo,

vielen Dank für die rege Beteiligung und die guten Lösungsansätze. Habe es jetzt mit einer Hilfsfunktion gelöst, die mir die CSV-Datei auf einer temporären als Text formatierten Excel-Arbeitsmappe einliest und zwischenspeichert. Hat den Vorteil, dass man dieser leeren Arbeitsmappe bei Bedarf alle möglichen Formatierungen mitgeben kann.

Ich stelle die Funktion auch mal hier zur Verfügung, falls jemand ein ähnliches Problem mit dem einlesen von CSV nach Excel und den daraus folgenden falschen Feld-Formatierungen haben sollte.
Hat allerdings bisher noch 3 Einschränkungen, da diese bei unserem Einsatzzweck alle nicht auftreten können. Sollte aber kein Ding sein dies bei Bedarf noch zu erweitern.
- Separator-Zeichen innerhalb von Nutzdaten werden nicht abgefangen
- keine Berücksichtigung von Datenklammerzeichen
- CSV-Dateien, die nur aus einer einzigen Spalte bestehen, werden falsch eingelesen

Delphi-Quellcode:
function CsvToExcel(Eingabe:string):boolean;
var
  CsvArray:TStringDynArray;
  ArrayMax, SegmentNr, Zeile, Spalte, PosUmbruch, Zeilenumbruchnacher:integer;
  CsvExcel:variant;
begin
  Eingabe := StringReplace(Eingabe,#$D#$A,'<><><>',[rfReplaceAll]); //Zeilenumbruch abfangen, da hiermit innerhalb des Arrays nicht mehr gearbeitet werden kann
  CsvArray := explode(';', Eingabe); //explode und StringReplace bei großen Dateien besser durch etwas schnelleres ersetzen!
  SegmentNr := 0;
  Zeile := 1;
  Spalte := 1;
  CsvExcel := CreateOLEObject('Excel.Application');
  try
    CsvExcel.Visible:=false;
    CsvExcel.DisplayAlerts:=false;
    CsvExcel.Workbooks.Open(ExtractFilePath(ParamStr(0))+'resources\csv.xls');
    CsvExcel.Workbooks[1].Worksheets[1].Select;

    repeat
      if (CsvArray[0+SegmentNr] <> '') and (copy(CsvArray[0+SegmentNr],1,6) <> '<><><>') then begin
        if (POS('<><><>',CsvArray[0+SegmentNr]) > 0) then begin
          PosUmbruch := PosEx('<><><>', CsvArray[0+SegmentNR]);
          CsvExcel.cells[Zeile,Spalte] := copy(CsvArray[0+SegmentNR], 1, PosUmbruch-1);
          Spalte := 1;
          Zeile := Zeile+1;
          CsvExcel.cells[Zeile,Spalte] := copy(CsvArray[0+SegmentNR], PosUmbruch+6);
          SegmentNr := SegmentNr+1;
          Spalte := Spalte+1;
          continue;
        end
        else begin
          CsvExcel.cells[Zeile,Spalte] := CsvArray[0+SegmentNR];
          SegmentNr := SegmentNr+1;
          Spalte := Spalte+1;
          continue;
        end;
      end
      else if (copy(CsvArray[0+SegmentNr],1,6) = '<><><>') then begin
        Spalte := 1;
        Zeile := Zeile+1;
        CsvExcel.cells[Zeile,Spalte] := copy(CsvArray[0+SegmentNR],7);
        SegmentNr := SegmentNr+1;
        Spalte := Spalte+1;
        continue;
      end
      else begin
        SegmentNr := SegmentNr+1;
        Spalte := Spalte+1;
        continue;
      end;
    until (SegmentNr = length(CsvArray)-1);

    except begin
      CsvExcel.quit;
      CsvExcel := unassigned;
      Result := false;
      exit;
    end;
  end;
  CsvExcel.ActiveWorkBook.SaveAs(ExtractFilePath(ParamStr(0))+'resources\'+'tmp.xls');
  CsvExcel.quit;
  CsvExcel := unassigned;
  Result := true;
end;
  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 13:42 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 by Thomas Breitkreuz