AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi paradox-daten als csv speichern
Thema durchsuchen
Ansicht
Themen-Optionen

paradox-daten als csv speichern

Ein Thema von bastos · begonnen am 4. Jun 2003 · letzter Beitrag vom 7. Jun 2003
Antwort Antwort
bastos

Registriert seit: 29. Mai 2003
15 Beiträge
 
#1

paradox-daten als csv speichern

  Alt 4. Jun 2003, 15:18
hallo,
ich möchte gerne meine daten aus der paradox-db als eine csv-datei abspeichern, um sie in excel wieder zu verwenden.
ich habe gelesen, dass man die daten in eine TStringList mit ; getrennt schreiben soll und dann als .csv speichern soll, aber wie macht man das konkret?

mfg
bastos
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2
  Alt 4. Jun 2003, 16:02
Geh in zwei verschachtelten Schleifen die die felder und die Datensaetze deiner Anwendung durch.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
bastos

Registriert seit: 29. Mai 2003
15 Beiträge
 
#3
  Alt 4. Jun 2003, 16:33
hi,
habe das jetzt so:

Delphi-Quellcode:
procedure TFormMain.Button2Click(Sender: TObject);
 var sl: TStringList;
begin
Query3.close;
Query3.SQL.text :='select * from member order by Nr';
Query3.Open;
sl:=TStringList.Create;
while not Query3.Eof do
  begin
  try
    sl.Add(Query3.fieldByName('Name').AsString);
    sl.SaveToFile('c:\test.txt');
  finally
   end;
  sl.free;
 end;
end;
leider hat er nur einen datensatz gespeichert und danach eine fehlermeldung ausgegeben."access violation at adress... in module..."
was mache ich noch falsch?
mfg
bastos
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#4
  Alt 5. Jun 2003, 07:28
Zunächst fehlt: Query3.next Wichtiger ist jedoch, dass das SaveToFile und Free der Stringlist außerhalb der While-Schleife erfolgen sollten! Und für eine "echte" csv-Datei fehlt noch das trennzeichen (Komma oder Semikolon).
  Mit Zitat antworten Zitat
Benutzerbild von eddy
eddy

Registriert seit: 4. Jan 2003
Ort: Sachsen
573 Beiträge
 
Delphi 5 Professional
 
#5
  Alt 6. Jun 2003, 23:43
Hallo bastos,

getestet und funktionsfähig:

Code:
procedure TFBrowser.ANSII1Click(Sender: TObject);
var
  abbr : boolean;
  headtxt, tx, s : string;
  i, j : integer;
  v : variant;
  ftyp : TFieldType;
begin
  if not Tab1.Active then exit;
  headtxt := FBrowser.Caption;
  s := ExtractFileName(Tab1.TableName);
  s := Copy(s,1,Pos('.',s)) + 'TXT';
  AssignFile(f, BrowDataPath + s);
  FBrowser.Caption := FBrowser.Caption + '    ' + Upper(BrowDataPath) + Lower(s);
  {$I-}
  Rewrite(f);
  if (IOResult) = 0 then begin
    InitGau(BotGau, Tab1);
    Tab1.DisableControls;
    tx := '';
    for i:= 0 to Tab1.FieldCount - 1 do begin
      if i > 0 then s := Tab1.FieldDefs.Items[i].Name;
      tx := tx + Upper(s);
      if i < Tab1.FieldCount - 1 then tx := tx + ';';
    end;
    WriteLn(f,tx);
    abbr := IOResult <> 0;
    Tab1.First;
    while (not abbr) and (not Tab1.Eof) do begin
      tx := '';
      for i:= 0 to Tab1.FieldCount - 1 do begin
        s := '';
        v := Tab1.Fields[i].AsVariant;
//        if v = Null then begin
//          ftyp := Tab1.FieldDefs.Items[i].DataType;
//        end;
        ftyp := Tab1.FieldDefs.Items[i].DataType;
        try
        case ftyp of
          ftString   :   if v = Null then s := '' else s:=Tab1.Fields[i].AsString;    { Zeichen- oder Stringfeld';}
          ftAutoInc  :   if v = Null then s := '' else str(v:20:0,s);                 { Autoinkrement-32-Bit -Integer-Feld als Zählerfeld}
          ftBytes    : if v = Null then s := '' else str(v:5:0,s);                  { Feste Anzahl von Bytes (binäre Speicherung)}
          ftSmallint,                                  { 16-Bit-Integer-Feld}
          ftInteger,                                   { 32-Bit-Integer-Feld}
          ftWord     :   if v = Null then s := '' else str(v:20:0,s);                 { Vorzeichenloses 16-Bit-Integer-Feld}
          ftBoolean  :
            if v = Null
              then s := 'Falsch'                            { Logisches Feld}
            else
            if v = true then s := 'Wahr' else s := 'Falsch';
          ftFloat,                                     { Numerisches Gleitkommafeld}
          ftCurrency :                                { Währungsfeld}
            begin
              if v = Null then v := 0;
              str(v:20:4,s);
              if Pos('.',s) > 0 then s := Copy(s,1,Pos('.',s)-1) + ',' + Copy(s,Pos('.',s)+1,length(s));
            end;

          ftDate     :   if v = Null then s := '' else s := DateToStr(v);     { Datumsfeld}
          ftTime     :   if v = Null then s := '' else s := TimeToStr(v);       { Zeitfeld}
          ftDateTime :   if v = Null then s := '' else s := DateTimeToStr(v);   { Feld für Datum und Zeit}

          ftBCD      : s:='#BCD#';        { Binärcodiertes Dezimalfeld}
          ftVarBytes :   s:='#VarBytes#';   { Variable Anzahl von Bytes (binäre Speicherung)}
          ftBlob     : s:='#Blob#';       { BLOB-Field}
          ftMemo     : if v = Null then s:='#Memo#' else s := v;       { Memofeld für Text}
          ftGraphic  :   s:='#Graphic#';    { Bitmap-Feld}
          ftFmtMemo  :   s:='#FMemo#';      { Formatiertes Memofeld für Text}
          ftParadoxOle:   s:='#PdoxOle#';    { Paradox-OLE-Feld}
          ftDBaseOle:   s:='#dBaseOle#';   { dBASE-OLE-Feld}
          ftTypedBinary:s:='#Binary#';     { Typisiertes Binärfeld}
        else
          s:='#???#';                      { Unbekannt oder unbestimmt}
        end; {end of case}
        except
          on E: Exception do s := '';
        end;
{        if Copy(s,1,1) <> '#' then begin}
          s := trim(s);
          j := Pos(';',s);
          while j > 0 do begin
            if j < length(s)
              then s := copy(s,1,j-1) + ',' + copy(s,j+1,length(s))
              else s := copy(s,1,j-1);
            j := Pos(';',s);
          end;

          tx := tx + s;
          if i < Tab1.FieldCount - 1 then tx := tx + ';';
{        end;}
      end; {of for i := 0 to FieldCount - 1}
      WriteLn(f,tx);
      abbr := IOResult <> 0;
      RefreshGau(BotGau); {, _rc_gau, _zel_gau, _rcg_gau);}
      Tab1.Next;
    end; {end of while}
    CloseGau(BotGau);
    Tab1.First;
    Tab1.EnableControls;
  end
  else begin
    {Fehler beim Erstellen der Export-Datei}
  end;

  CloseFile(f);
  {$I+}
  FBrowser.Caption := headtxt;
end;
Hab' ich schon vor einiger Zeit geschrieben, steht vielleicht ein bischen mehr drin als nötig, aber als Beispiel sollte es funktionieren.

mfg
eddy
  Mit Zitat antworten Zitat
Benutzerbild von Specialwork
Specialwork

Registriert seit: 10. Jan 2003
Ort: Schwall
71 Beiträge
 
Delphi 8 Professional
 
#6

Tabellen ins CSV Format kopieren

  Alt 7. Jun 2003, 00:47
Hallo Bastos,

Hab Dir mal eine kleine Komponente entwickelt.

Die Komponente ist abgeleitet von TQuery. Du must also die üblichen Schritte durchführen, um eine Verbindung mit einer Datenbank zu erstellen. Dann musst Du lediglich die Eigenschaften ExportFile und Seperator einstellen und die Funktion ExportAsCSV aufrufen.

Delphi-Quellcode:
unit QueryExport;

interface

uses
  Windows, Messages, SysUtils, Classes, DB, DBTables;

type
  TQueryExport = class(TQuery)
  private
    { Private-Deklarationen }
    fExportFile: String;
    fSeperator: String;
  protected
    { Protected-Deklarationen }
  public
    { Public-Deklarationen }
    procedure ExportAsCsv;
  published
    { Published-Deklarationen }
    property ExportFile: String read fExportFile write fExportFile;
    property Seperator: String read fSeperator write fSeperator;
  end;

procedure Register;

implementation

procedure Register;
begin
  RegisterComponents('Specialwork Database', [TQueryExport]);
end;

procedure TQueryExport.ExportAsCsv;
var
  ExportedStrings: TStringList;
  Y: Integer;
  CurrentDataset: String;
begin
  ExportedStrings:=TStringList.Create;
  try
    try
      if Active then begin
        while not Eof do begin
          CurrentDataset:='';
          for Y:=0 to Fields.Count-1 do begin
            CurrentDataset := CurrentDataset + Fields[y].AsString;
            CurrentDataset := CurrentDataset + Seperator;
          end;
          ExportedStrings.Add(CurrentDataset);
          Next;
        end;
      end;
      ExportedStrings.SaveToFile(ExportFile);
    except
      on E: Exception do begin
        OutputDebugString(PChar(E.Message));
      end;
    end;
  finally
    ExportedStrings.Free;
  end;
end;

end.
Gruß, Tom
Angehängte Dateien
Dateityp: zip queryexport.zip (676 Bytes, 36x aufgerufen)
Thomas van Veen
Es gibt keine Probleme, nur Lösungen, auf die man nicht gleich kommt !
  Mit Zitat antworten Zitat
Antwort Antwort


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 09:10 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