AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Problem mit .dbf als Austauschformat mit Excel
Thema durchsuchen
Ansicht
Themen-Optionen

Problem mit .dbf als Austauschformat mit Excel

Ein Thema von Jumpy · begonnen am 10. Apr 2014 · letzter Beitrag vom 11. Apr 2014
Antwort Antwort
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#1

Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 10:09
Datenbank: Oracle • Version: 11g • Zugriff über: ADO
Hallo,

es gibt bei uns ein uraltes, die BDE benutzendes Tool, das es ermöglicht SQL-Statements gegen diverse Datenbanken zu schießen und die Ergebnismenge in eine .dbf-Datei zu speichern.

Dies sollte ohne großen Aufwand so umgebaut werden, dass es ohne BDE läuft und ich benutze nun TBDF zur Erzeugung der .dbf-Datei.

Ich hab nun das Problem, dass die Umlaute falsch ankommen, wenn ich die Datei in Excel 2007 wieder öffne. Schau ich mir die Datei im Texteditor an, oder importiere ich sie mal testweise in Access, kommen die Umlaute richtig rüber.
Ich bin fast geneigt, das als Excel-Problem abzutun und habe so ziemlich alle CodePage/LanguageID Varianten, die man in der TDBF-Klasse so angeben kann und die mir sinnvoll schienen ausprobiert - ohne Erfolg.

Hat irgendwer da vllt. noch einen Rat für mich?
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 10:49
Wenn du schon Umbaust dann schmeiss doch das DBF-Format auch weg und nimm entweder ein Txt/CSV-Format oder XLS.

Ein Teil der Probleme die man hat liegen nicht an der BDE sondern am Speicherformat DBF!
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#3

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 11:23
Hallo,

andere Formate konnte das Programm schon (csv, xls). Ich hab jetzt noch XML hinzugefügt (TDataSet.SaveToFile) und wollte das .dbf wieder ans Laufen kriegen.

Hintergrund ist, dass die Kollegen die das benutzen Gewohnheitstiere sind und die weiteren Daten nachher für irgendwelche Spielereien Analysen in Excel brauchen.

Kleine Datenmengen werden dann direkt per Excel-Automation in eine .xls Datei geschrieben. Das ist aber bei großen Datenmengen recht langsam, weswegen man dann immer den Umweg über .dbf benutzt hat, weil das dann schnell ging und es keine Probleme mit den Datentypen gab.

CSV hat beim Import das Problem, dass man schon mal Probleme mit Datums(?) hat oder das führende Nullen, bei z.B. Personalnummern, weggelassen werden. Das kann man zwar idR verhindern, wenn man den Importdialog/-assistenten mit ein bisschen Verstand durcharbeitet, aber am dem bisschen scheitert es manchmal. Und der Programmierer ist dann immer schuld.

----------------------

Edit:
Habe gerade mal einen Testdatensatz mit nur einem Feld mit einem "ö" drin exportiert.
Im Hex-Editor angeguckt, da ist das als "FC" drin was ja glaub ich ANSI ist?
Anschließend in Access importiert, wo das ja geht und von dort wieder in eine neue .dbf exportiert.
Diese kann nun Excel richtig einlesen, es kommt das "ö".
Dann hab ich mir das nochmal im Hex-Editor angeguckt und da ist jetzt das ö als "81" gespeichert.

Ist das vllt. ein Hinweis darauf was Excel erwartet? Ist die 81 auch ANSI, oder ASCII oder sonstwas? Ich bin immer von diesen Codierungen verwirrt.
Ralph

Geändert von Jumpy (10. Apr 2014 um 11:41 Uhr)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#4

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 12:08
Versuche, die Dateien direkt ins XLS(X)-Format zu schreiben.
Das geht über ADO recht flott (soweit ich weiß), mit DevExpress sehr sehr bequem (wenn auch teuer), mit Komponenten von Axolot-Data (XLSMini oder XLSReadWriteII) sehr schnell und mit anderen Komponenten (z.B. TMS Flexcel) auch.

Als Alternative für ein gängiges kleines DB-Format ginge auch Access, zumal die Jet-Engine eigentlich auf jedem Windows-PC installiert ist.

Such mal hier im Forum nach Möglichkeiten. Ich würde dieses schrottige DBF-'Format' nicht mehr verwenden, zumal das kein Standard ist (FoxPro erzeugt DBF)
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#5

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 14:37
Die genannten Komponenten kosten ja alle was und da wir das sonst nirgendwo brauchen würden (nach jetzigem Stand der Dinge) will man dafür keine Kohle locker machen. Generell tut sich unsere Firma schwer mit Komponenten kaufen, da wir zu klein sind und mit den Dingen, die bei Delphi dabei sind meist klar kommen.

Ich hab nun auf jeden Fall mal einen Excel-Export über ADO realisiert und das ist tatsächlich schneller, als die alte Exportfunktion, dafür schon mal schönen dank.

Das .dbf Problem hab ich nach einigem Nachdenken auch gelöst oder eher umgangen. Ich speichere mit US-Codepage. Dadruch werden z.B. im Texteditor die Umlaute nicht mehr richtig dargestellt.
Der Excel-Import aber kann die nun einlesen und Excel "interpretiert" die dann aber "deutsch" und stellt die Umlaute richtig dar.

Mag natürlich sein, dass das auf dem Rechner des nächsten Kollegen, der ein rein deutsches Windows oder Office hat (nicht das universal-alle-Sprachen-US-Englische), wieder ganz anders aussieht. Aber für's erste ist die Funktionalität wieder drin, und ein paar neue Exporterweiterungen sind noch hinzugekommen. Danke
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

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

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 10. Apr 2014, 23:31
Kleine Datenmengen werden dann direkt per Excel-Automation in eine .xls Datei geschrieben. Das ist aber bei großen Datenmengen recht langsam,....
"Langsam" ist ja relativ, meiner Meinung nach sind 10-20k Datensätze noch vertretbar.

CSV hat beim Import das Problem, dass man schon mal Probleme mit Datums(?) hat oder das führende Nullen, bei z.B. Personalnummern, weggelassen werden. Das kann man zwar idR verhindern, wenn man den Importdialog/-assistenten mit ein bisschen Verstand durcharbeitet, aber am dem bisschen scheitert es manchmal. Und der Programmierer ist dann immer schuld.
Tröste Dich Du bist da nicht alleine.
Was Die Datumse angeht, nimm doch das ISO-Format (YYYY.MM.DD oder YYYYMMDD) damit hatte ich bisher noch keine Probleme.

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

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#7

AW: Problem mit .dbf als Austauschformat mit Excel

  Alt 11. Apr 2014, 09:15
Was Die Datumse angeht, nimm doch das ISO-Format (YYYY.MM.DD oder YYYYMMDD) damit hatte ich bisher noch keine Probleme.
Gute Anregung. Muss ich mal testen. Bisher "looped" der CSV-Export einfach durch alle Datensätze und in jedem Datensatz durch alle Felder und schreibt das mit Query.Field[i].AsString in eine Stringlist.

Das kann man ja aufbohren, das abhängig vom Datentyp des Feldes was gemacht wird.
Ralph
  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:02 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