Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 14-02-2016
joseprad joseprad is offline
Miembro
 
Registrado: oct 2006
Posts: 36
Poder: 0
joseprad Va por buen camino
Lectura hoja Excel con ADO

Hola amigos.
Me ha salido un problema que no se por donde cogerlo y necesito vuestra ayuda.
Estoy leyendo un fichero Excel mediante los componentes ADO con el código siguiente:
Código Delphi [-]
procedure TfrmImportExcel.ObrirFixerADO;
var
  NomFixer: string;
begin
  NomFixer := 'G:\Manteniment preus\FixersImportats\Feliu Boet 9-2015.xls';
  with FxEx.conADO do begin
    Close;
    LoginPrompt := False;
    ConnectionString :=
      'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' + NomFixer +
      ';Extended Properties=Excel 8.0';
    Connected := True;
  end;
end;

procedure TfrmImportExcel.LeerRegistros:
begin
 with FxEx.dsFulla do begin
    if not Active then
      Open;
    First;
    while not Eof do begin
      gn := grdLlista.Rows.Add;
      gn.Value[1] := FieldByName('Referencia').asstring;//Fields.FieldByNumber(3).AsString;
      gn.Value[2]:=  Fields.FieldByNumber(4).AsString;
      Next;
    end;
end;
Para mayor comprensión adjunto capturas de pantalla.
Lo que ocurre es que tal como se puede ver, si el registro 'referencia' tiene un carácter que no sea numérico me deja el campo en blanco.
He cambiado el formato de la columna de Excel a texto, pero sigue igual.
Sabe alguien porque?.
Gracias por la molestia.
Responder Con Cita
  #2  
Antiguo 14-02-2016
Avatar de AgustinOrtu
[AgustinOrtu] AgustinOrtu is offline
Miembro Premium
NULL
 
Registrado: ago 2013
Ubicación: Argentina
Posts: 1.858
Poder: 15
AgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en brutoAgustinOrtu Es un diamante en bruto
Como esta grabado el excel? El formato es el xls o xlsx?

Yo he tenido problemas con el ultimo, por eso siempre los grabo como xls

Proba acceder al campo usando .Value

Evalua el valor de la propiedad DataType del objeto TField


En este enlace hay mas ConnectionStrings con los que podes jugar

Por ejemplo, esta para el proveedor ACE o esta para el proveedor JET
Responder Con Cita
  #3  
Antiguo 15-02-2016
joseprad joseprad is offline
Miembro
 
Registrado: oct 2006
Posts: 36
Poder: 0
joseprad Va por buen camino
Muchas gracias Agusti.
La hoja de Excel es .xls pero con ACE se solucionó el problema.
La cadena de conexión queda asi y funciona correctamente:
Código Delphi [-]
ConectionString :='Provifer=Microsoft.Ace.OLEDB.12.0; Data Source = FullaExcel.xls;Extended Properties=Excel 8.0';
En los enlaces que me indicas queda perfectamrnte explicado, pero sin utilizar HDR=Yes, ya que si lo utilizas tira un error.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
como mandar un dbgrid a una hoja de excel de solo lectura ddd_ddd Varios 1 06-09-2006 20:05:10
Abrir Excel en Modo Lectura sanpra Servers 2 14-06-2006 14:21:54
Hoja Excel via web Nbull Varios 0 02-02-2006 11:11:36
Exportar a excel con mas de 1 hoja Perio Varios 6 25-01-2006 17:03:48
Ejemplo de Lectura/escritura en MS Excel Yarri Conexión con bases de datos 3 14-05-2003 16:06:44


La franja horaria es GMT +2. Ahora son las 15:15:11.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi