AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Excel Sheet per ADO auslesen -> Erste Zeile und Spalte fehlt
Thema durchsuchen
Ansicht
Themen-Optionen

Excel Sheet per ADO auslesen -> Erste Zeile und Spalte fehlt

Ein Thema von little_budda · begonnen am 6. Feb 2009 · letzter Beitrag vom 9. Feb 2009
Antwort Antwort
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#1

Excel Sheet per ADO auslesen -> Erste Zeile und Spalte fe

  Alt 6. Feb 2009, 19:58
Hallo,

ich nutze folgenden Code um ein Excel Blatt auszulesen.
Delphi-Quellcode:
...
  if ADOConnectionExcelVV.Connected then ADOConnectionExcelVV.Close;
  ADOConnectionExcelVV.ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;' +
                                           'Data Source='+ OpenDialog1.FileName +';' +
                                           'Extended Properties="Excel 8.0;HDR=Yes";' +
                                           'Persist Security Info=False';
  ADOConnectionExcelVV.Open;
  if ADOConnectionExcelVV.Connected then
    begin
      ADOConnectionExcelVV.GetTableNames(slTableList, False);
      sTableName:= slTableList[0];
      ADODataSetExcelVV.CommandText:= 'SELECT * FROM [' + sTableName + ']';
      ADODataSetExcelVV.Open;

      // Zuweisen der Tabellenzeilen
     iMaxVvTableRows := ADODataSetExcelVV.RecordCount;
     setlength(tabellenfelder, (iMaxVvTableRows + 1));

      // Anzahl der Spalten ermitteln
      iMaxCol := ADODataSetExcelVV.FieldCount;

      // Auf den ersten Datensatz springen
      ADODataSetExcelVV.First;

      // Dataset auslesen
      for iRow := 1 to iMaxVvTableRows do
        begin
          for iCol := 1 to iMaxCol do
            begin
              tabellenfelder[iRow].aTableRow[iCol] := ADODataSetExcelVV.Fields[(iCol - 1)].AsString
            end;
          ADODataSetExcelVV.Next;
        end;
      ADODataSetExcelVV.Close;
    end;
  ADOConnectionExcelVV.Close;

...
Leider fehlt mir in den ausgelesenen Daten die erste Zeile und die erste Spalte der Tabelle.
Was bitte mache ich denn falsch?


Gruß Holger.

Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
Gargoyl

Registriert seit: 11. Mär 2007
69 Beiträge
 
#2

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 6. Feb 2009, 20:09
ich ziehe meinen Beitrag lieber zurück ... war eh nur Blödsinn glaube ich
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#3

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 6. Feb 2009, 20:26
Hallo,

ich bin mir zwar nicht sicher, aber die Variablen iRow und iCol sollten doch mit 0 beginnen oder ?

Jens
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 6. Feb 2009, 20:31
Setze HDR=No im Connectionstring, wenn die erste Zeile daten und keine Feldbezeichner enthält.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#5

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 6. Feb 2009, 20:52
Die Korrektur des Connections Strings hat mein Problem teilweise gelöst.

Wenn jetzt in der ersten Spalte der Tabelle Zahlen eingetragen sind,
werden die Zellen mit einem leeren String zurückgegeben.
Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 6. Feb 2009, 21:51
Das liegt an dem Versuch von Excel bzw. der Jet Engine, den Datentyp automatisch festzustellen. Du kannst versuchen im Connectionstring MaxScanRows=0 einzutragen, dann werden nicht nur die ersten 8 Zeilen jeder Spalte analysiert sondern alle. Aber falls in den Spalten verschiedene Datentypen auftauchen, kann dies sowieso zu lustigen Problemen führen.
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#7

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 9. Feb 2009, 06:09
Habe ich nicht eine Chance zu sagen das alle Zellen als Text gelesen werden sollen?
Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.487 Beiträge
 
Delphi 7 Enterprise
 
#8

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 9. Feb 2009, 07:21
Ja, indem Du in Excel alles als Text formatierst
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#9

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 9. Feb 2009, 07:27
Nett gemeinter Tipp.
Leider habe ich auf die Tabelle nur Leserechte.
Ich hatte gehofft das alles über den ConnectionSting machen zu können.
Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#10

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt

  Alt 9. Feb 2009, 10:12
Hallo,

schau mal bitte hier http://support.microsoft.com/kb/257819/de, ob Dir das eventuell weiterhelfen kann.

Was Du mal probieren könntest (ich weiß allerdings nicht, ob das bei Excel überhaupt unterstützt wird):
Delphi-Quellcode:
ADODataSetExcelVV.CommandText:= 'SELECT
Cast(Spaltenname1 As VarChar(256)) As Spaltenname1,
Cast(Spaltenname2 As VarChar(256)) As Spaltenname1,
...
FROM [
' + sTableName + ']';
Damit könnte die Möglichkeit bestehen, im Select den Datentyp vorzugeben.
Was ich nicht weiß: Kann man bei Excel die Spaltenname abfragen? Es könnte eventuell mit
Delphi-Quellcode:
Var
  slFieldList : TStringList;
  sCommandText : String;
  i : Integer;
begin
  slFieldList := TStringlist.Create;
  sCommandText := select ';
...
ADODataSetExcelVV.GetFieldNames(slFieldList);
for i := 0 to slFieldList.Count - 1 do begin
sCommandText := sCommandText +
'Cast(slFieldList[i] + ' as VarChar(256)) As ' + slFieldList[i] + ', ';
  end;
  sCommandText := sCommandText + FROM [' + sTableName + ']';
ADODataSetExcelVV.Open;
...
end;
funktionieren.
Dashier ist nicht getestet, sondern nur mal so hingeschrieben, in der Hoffnung, dass es bei der Problemlösung behilflich sein könnte.
  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 02:32 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