Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 03-06-2010
Avatar de ingabraham
ingabraham ingabraham is offline
Miembro
 
Registrado: ago 2007
Posts: 614
Poder: 17
ingabraham Va por buen camino
”ajustar texto” a las celda de excel una vez exportado

Hola,
Necestito lo sgte:
1. necesito ”ajustar texto” a las celda de excel una vez exportado.
Debido a q exporto datos con mucha logitud de texto y me sale muy feo en excel.

2. que me muestre una vez exportado el archivo excel, que se anteponga sobre los demas archivos y me lo muestre, debido a que me lo deja en la barra de tarea.


Este es mi codigo de exportaciòn, funciona tdo bien.
Código Delphi [-]

//..............................................................................
//    EXPORTAR UN DBGRID A EXCEL
//..............................................................................
procedure TPrincipal.exportarGridExcel (mGrid : tdbgrid; lab:Tlabel);
var
  rangoExcel : VARIANT; // REEMPLAZO POR DELPHI7 TIPO. Excel2000.range;
  i, fila : integer;
  mMarcador : Tbookmarkstr;
  mTabla : tdataset;
  aplicacionExcel : TExcelApplication;
begin
Try
    Screen.Cursor := crHourGlass;
    Tlabel(Lab).Font.Color:=clRed;
    Tlabel(Lab).Font.Name:='Georgia';
  //creamos libro excel (abriendo Excel)
  aplicacionExcel := TExcelApplication.Create(nil);
  //asociamos el dataset (tabla) del DBGrid con la tabla
  //que utilizaremos en esta función
  mTabla := mGrid.datasource.dataset;
  //mostramos Excel
  //aplicacionExcel.Visible[0] := true;
  //creamos un nuevo libro de Excel
  aplicacionExcel.workbooks.add(NULL, 0);
  //primera fila con los nombres de las columnas
  //para ello recorremos todos las columnas de la tabla
  //y mostramos en Excel el valor de "DisplayLabel"
  rangoExcel := aplicacionExcel.ActiveCell;
  for i:= 0 to mTabla.Fields.Count - 1 do
  begin
    rangoExcel.Value := mTabla.Fields[i].DisplayLabel;
    rangoExcel := rangoExcel.Next;
  end;
  //aplicamos un autoformato de Excel a las filas y columnas añadidas
  rangoExcel.AutoFormat(10, NULL, NULL, NULL, NULL, NULL, NULL);
  mTabla.DisableControls;
  try
    mMarcador := mTabla.Bookmark;
    try
      //recorremos todos los registros de la tabla para ir añadiéndolos
      //a la hoja actual de Excel
      mTabla.First;
      fila := 2;
      while not mTabla.Eof do
      begin
        rangoExcel := aplicacionExcel.Range['A' + inttostr(fila), 'A' + inttostr(fila)];
        //recorremos todos las columnas del registro actual
        for i := 0 to mTabla.Fields.Count - 1 do
        begin
         If ( (mTabla.Fields[i].DisplayLabel='P_FECHA')or (mTabla.Fields[i].DisplayLabel='FECHA')or (mTabla.Fields[i].DisplayLabel='E_FECHAINGRESO')) then
           rangoExcel.Value := mTabla.Fields[i].AsDateTime
          else
           If ((mTabla.Fields[i].DisplayLabel='FECHA_RETIRO')And (Not(mTabla.Fields[i].IsNull)) ) Then
              rangoExcel.Value := mTabla.Fields[i].AsDateTime
           Else
            rangoExcel.Value := mTabla.Fields[i].AsString;
          rangoExcel := rangoExcel.Next;
        end;
        mTabla.Next;
        Inc(fila);
        Tlabel(Lab).Caption:='Exportando... Fila Nro.'+IntToStr(Fila);
      end;
      finally
        mTabla.Bookmark := mMarcador;
      end;
    finally
      mTabla.EnableControls;
    end;
     Tlabel(Lab).Font.Color:=clNavy;
     Tlabel(Lab).Caption:='Exportación Terminada!.';
         Screen.Cursor := crDefault;
    //mostramos Excel
   aplicacionExcel.Visible[0] := true;

   aplicacionExcel.Disconnect;
except
 on exception do
 begin
    //aplicacionExcel.Disconnect;     // comentariado debido a error de inicialización, realizar seguimiento.
    aplicacionExcel.Quit;
    messagedlg(' la exportación de datos, Esta Terminando su Proceso.',mterror,[mbok],0);
  end;
end;
end;
__________________
Enseñar es la virtud de un sabio.
Responder Con Cita
  #2  
Antiguo 04-06-2010
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.267
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Pues ya lo tienes casi hecho.
En mi caso, el ejemplo que comentas, ya aparece abierto y sobre el resto de ventanas. Uso XP y D6.

En cuanto al ancho de columnas, como prueba, antes del TRY puedes colocar este código:

Código Delphi [-]
  // Anchos de columna
  rangoExcel := aplicacionExcel.Range['A1','A20'];
  rangoExcel.ColumnWidth := 5;
  rangoExcel := aplicacionExcel.Range['B1','B20'];
  rangoExcel.ColumnWidth := 10;
  rangoExcel := aplicacionExcel.Range['C1','C20'];
  rangoExcel.ColumnWidth := 15;
  rangoExcel := aplicacionExcel.Range['D1','D20'];
  rangoExcel.ColumnWidth := 20;
  rangoExcel := aplicacionExcel.Range['E1','E20'];
  rangoExcel.ColumnWidth := 25;
  rangoExcel := aplicacionExcel.Range['F1','F20'];
  rangoExcel.ColumnWidth := 40;

En fçacil, ahora puedes adaptarlo y colocarlo donde necesites.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 15-12-2010
Rowerto Rowerto is offline
Miembro
 
Registrado: abr 2010
Posts: 20
Poder: 0
Rowerto Va por buen camino
No se si se refiere a esto pero:

- Para que solo se vea cuando acabes de hacer todo:
Código Delphi [-]
      
      coinitialize(nil);
      Excel         := CreateOleObject('Excel.Application');
      ExcelDoc      := Excel.Workbooks.Add;
      WS            := ExcelDoc.ActiveSheet;
      Excel.Visible := false;

  // aqui el procedimiento que quieras

      Excel.Visible := true;

- Para que se ajusten los tamaños de las celdas:
Código Delphi [-]
ws.cells.entirecolumn.autofit;
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
Ajustar DetailBand al texto salvanano Impresión 2 26-07-2007 19:04:01
Ajustar la posición al tamaño del texto Carmelo Cash Impresión 2 12-07-2006 22:40:24
celda excel Alejandro Horns Tablas planas 1 29-07-2005 09:19:29
Ajustar un Form al ancho de un texto salvica Varios 10 01-05-2004 04:11:02
Como ajustar y/o desplazar texto judoboy Impresión 3 21-07-2003 20:08:50


La franja horaria es GMT +2. Ahora son las 17:00:32.


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