Ir al contenido principal

Excel y la clase TOleAuto

El día de hoy se publico en el foro de noticias de fivewin un mensaje que me llamó la atención.

Hola
Estoy utilizando TExcelScript y me veo en la necesidad de insertar saltos de
página en la hoja de Excel.

En la documentación de VBA me viene que hay que hacer:
ActiveSheet.HPageBreaks.Add Before:=ActiveCell
¿Cómo se traduce esto a cristiano?
Otra cosa.
A veces veo en los métodos que se utiliza :
::oSheet:PageSetup:Set( "printarea" , cRange ) ó ::oCell := ::oExcel:Get( "ActiveCell")
¿Cúal es la convención de llamadas para usar Set o simplemente hacer " :=
cRange"
Paco García

Ok .... vamos por partes...

ActiveSheet.HPageBreaks.Add Before:=ActiveCell

ActiveSheet es una clase de Excel y nosotros la podemos manejar desde la clase TExcelScript con la Data oSheet que guarda el Objeto de la hoja de trabajo activa.

oExcel:oSheet

ActiveSheet.HPageBreaks.Add Before:=ActiveCell

HPageBreaks es una propiedad de la clase ActiveSheet ( oExcel:oSheet ) , en donde nosotros la podemos manejar con los métodos Set() , Get() o Invoke() , siguiendo esta lógica nuestro código quedaría así.

oExcel:oSheet:HPageBreaks

La propiedad HPageBreaks tiene propiedades y funciones , aquí es donde es muy importante saber que método de la clase TOleAuto debemos de aplicar.

Y realmente es muy sencillo , la regla es la siguiente , todas las propiedades de Excel las vamos a acceder con Set() y Get() , para las funciones usamos el método Invoke()

Conociendo esto solamente nos resta revisar la sintaxis de la propiedad HPageBreaks y saber si "Add" es una función o un método.

La sintaxis de HPageBreaks nos muestra que "Add" es una función y que recibe un parámetro tipo Objeto que indica la celda activa donde se va insertar nuestro salto de página.

Ahora nuestro código queda de la siguiente forma :

oExcel:oSheet:HPageBreaks:Invoke("Add")

únicamente nos hace falta el parámetro tipo Objeto que se envía a la función Add() de la propiedad HPageBreaks.

Ese valor lo podemos obtener de dos formas :

1.- Obteniendo la celda activa

oCell := oExcel:GetCell()

2.- Especificando una dirección .

oCell := oExcel:SetPos( "A5")

El código resultante de todo esto sería.

oExcel:oSheet:HPageBreaks:Invoke("Add", oCell )

¡¡¡ y ……… listo el pollo !!!

Comentarios

Anónimo dijo…
Muy buena explicación Vikthor, con esto ya se puede seguir agregándoles mas opciones a la TExcelScript.

Saludos,

Carlos Sincuir
tecnisistemas@guate.net.gt
Anónimo dijo…
gracias voy a probarlo y os cuento

Entradas más populares de este blog

Fragmentos

"Hoy desperté, te busqué, me hizo falta estar contigo..." "Con un nudo en la garganta y el alma hecha pedazos, ..." , "quién me iba a decír cuando fuí feliz que tendría un fin, que así son las cosas..." , "dulce sentimiento, de nada me arrepiento , que vivan los momentos en tu boca y en tu cuerpo..." , "en cada caricia amanecía un nuevo sol, más nunca es para siempre, no no no no , no fue para siempre..." , "no me escucha el corazón, no te deja de sentir, sé que no se rendirá, no entiende que no eres para mí...", "puedo morirme mañana, puede secarse mi alma, pero nunca te olvidaré..." , "sólo tengo tiempo, en mi soledad para recordar, sólo me quedan fuerzas para soñar..." "y hoy dibujaré suavemente un verso en mi voz, para dártelo..." "Noooo, no voy a verte más, no pensaré en tí..." , "Yo no sé si tú, no sé si yo, seguiremos siendo como hoy..." "Yo simplemente...

¿ Problemas para descomprimir archivos ?

 Hoy en día hay muchas opciones para comprimir información, existen algoritmos que permiten comprimir distintos tipos de archivos. Los formatos Zip y Rar son comunmente utilizados en Windows, los formatos Tar, Gzip, Bzip2 son utilizados en Linux y Unix. ¿ Qué hacer cuándo se presenta la necesidad de descomprimir un archivo en alguno de los formatos mencionados y no tienes instalado el software necesario en tu equipo ? Te recomiendo visitar  Cloudconvert , es un sitio en dónde podrás convertir archivos de un formato de compresión a otro sin necesidad de instalar software, la convesión es realizada en línea. La versión libre te permite realizar hasta 25 convesiones por día.

El triste

"Hasta el mejor libro... tiene final." No recuerdo al autor. "Qué triste todos dicen que soy, que siempre estoy hablando de ti..."  Esa cita es parte de la letra de una canción llamada "El triste" interpretada por José José... el día de hoy describe una parte de mi.