Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Delphi Excel Sheet per ADO auslesen -> Erste Zeile und Spalte fehlt (https://www.delphipraxis.net/128818-excel-sheet-per-ado-auslesen-erste-zeile-und-spalte-fehlt.html)

little_budda 6. Feb 2009 19:58


Excel Sheet per ADO auslesen -> Erste Zeile und Spalte fe
 
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.

:gruebel:

Gargoyl 6. Feb 2009 20:09

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
ich ziehe meinen Beitrag lieber zurück ... war eh nur Blödsinn glaube ich

Jens Hartmann 6. Feb 2009 20:26

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

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

Jens

Union 6. Feb 2009 20:31

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
Setze HDR=No im Connectionstring, wenn die erste Zeile daten und keine Feldbezeichner enthält.

little_budda 6. Feb 2009 20:52

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
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.

Union 6. Feb 2009 21:51

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
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.

little_budda 9. Feb 2009 06:09

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
Habe ich nicht eine Chance zu sagen das alle Zellen als Text gelesen werden sollen?

Union 9. Feb 2009 07:21

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
Ja, indem Du in Excel alles als Text formatierst ;)

little_budda 9. Feb 2009 07:27

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
Nett gemeinter Tipp.
Leider habe ich auf die Tabelle nur Leserechte.
Ich hatte gehofft das alles über den ConnectionSting machen zu können.

nahpets 9. Feb 2009 10:12

Re: Excel Sheet per ADO auslesen -> Erste Zeile und Spalt
 
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.


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:59 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-2025 by Thomas Breitkreuz