AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi DBgrid in csv - Problem
Thema durchsuchen
Ansicht
Themen-Optionen

DBgrid in csv - Problem

Ein Thema von deralexc · begonnen am 9. Mai 2006 · letzter Beitrag vom 9. Mai 2006
Antwort Antwort
deralexc

Registriert seit: 9. Mai 2006
3 Beiträge
 
#1

DBgrid in csv - Problem

  Alt 9. Mai 2006, 13:15
Datenbank: Access • Version: 2000 • Zugriff über: Adoquery
Moin!
Ich hab da ein Problem.
Ich soll einzelne Spalten verschiedener DB-Tabellen in eine csv schreiben um diese dann anschließend via php in mySQL einzufügen.

Ich bin hier eigentlich schon fündig geworden - einziges Problem:
die daten werden wie folgt gespeichert:

2,"LS Stochastik",1
6,"LS Analysis",1
8,Mathematik,1
10,Mathematik,1

sollte aber eigentlich so aussehen
"2","LS Stochastik","1"
"6","LS Analysis","1"
"8","Mathematik","1"
"10","Mathematik","1"

Hier mein Quelltext:
Delphi-Quellcode:
function Tmainform.buch:boolean;
var
  s, csv: TStrings;
  i: integer;
begin
  csv := TStringList.Create;
  s := TStringList.Create;
  with ADOQuery1 do
  begin
   begin
   ADOQuery1.Close;
   DataSource1.DataSet := ADOQuery1;
   ADOQuery1.SQL.Text:='select bookid,title,mediumid from bookstab';
   ADOQuery1.Open;
      while not Eof do
    begin
      s.Clear;
      for i := 0 to Pred(FieldCount) do
        s.Add(Fields[i].AsString);
      csv.add(s.CommaText);
      Next;
    end;
    Close;
  end;
  s.Free;
  csv.SaveToFile(ExtractFilePath(Application.Exename)+'\dbtxt\buch.txt');
  csv.Free;
  result:=true;
  end;
end;
Ich danke schonmal im voraus!

Mfg

Deralex
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: DBgrid in csv - Problem

  Alt 9. Mai 2006, 13:18
Vom Jediprojekt gibt es eine Komponente CSVDataSet.
Markus Kinzler
  Mit Zitat antworten Zitat
deralexc

Registriert seit: 9. Mai 2006
3 Beiträge
 
#3

Re: DBgrid in csv - Problem

  Alt 9. Mai 2006, 20:09
Ist das der einzige Weg? ist es nicht möglich mit ein wenig "feintuning" an der Variante die ich bisher gewählt habe das Problem zu lösen?

Jedi müsste ich auch erst installieren.

Gruß
Alex

PS: Beispiel-Code wäre echt hilfreich....
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#4

Re: DBgrid in csv - Problem

  Alt 9. Mai 2006, 21:03
Herzlich willkommen in der Delphi-PRAXiS, Alex.

Hier ein Nachrüst-Kit für dich:

Delphi-Quellcode:
function DelimitedText(s: TStrings; const cDelimiter: Char = ',';
  const cQuote: Char = '"'): String;
var
  i, iPos, iLength: Integer;
  line: String;
begin
  if s.Count = 0 then Result := 'else
  // calculate resulting length
  begin
    // account for delimiters
    iLength := Pred(s.Count);
    for i := 0 to Pred(s.Count) do
    begin
      line := s[i];
      // account for outer quotes
      Inc(iLength, Length(line) + 2);
      for iPos := 1 to Length(line) do
        // account for escape chars
        Inc(iLength, Ord(line[iPos] = cQuote));
    end;
    // dimension result
    SetLength(Result, iLength);
    iPos := 1;
    for i := 0 to Pred(s.Count) do
    begin
      if i > 0 then
      begin
        Result[iPos] := cDelimiter;
        Inc(iPos);
      end;
      line := AnsiQuotedStr(s[i], cQuote);
      Move(line[1], Result[iPos], Length(line));
      Inc(iPos, Length(line));
    end;
  end;
end;
Freundliche Grüße vom marabu
  Mit Zitat antworten Zitat
deralexc

Registriert seit: 9. Mai 2006
3 Beiträge
 
#5

Re: DBgrid in csv - Problem

  Alt 9. Mai 2006, 21:45
Danke! Prog läuft jetzt so wie's soll! Dickes Danke!
  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 04:47 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