Jump to content
JDG

Como controlar la apertura de excel?

Recommended Posts

Hola.

Mi pregunta es:

Desde que se hace click en un archivo excel y empieza a cargar hasta que recibe la primera instruccion que hay por ejemplo en el ThisKorbook o en un auto_open, ese proceso que a veces resulta en un parpadeo ¿donde se puede manipular para que no se vea?....no se si me explico. Es que a veces se ve (tarda mas) y a veces practicamente no se ve (apenas tarda nada).

Gracias.

Share this post


Link to post
Share on other sites

Gracias Alexander.

Esa instruccion la utilizo, pero no es la que me cumple para lo que yo quiero.

A ver si me explico:

Tomando como ejemplo tu recomendación, imagino que me dirias que el  application.ScreenUpdating=False lo coloque en el principio de un codigo en el Thisworbook (por ejemplo work_open) verdad?,

bueno pues mi necesidad o inquietud estaria en lo que sucede antes de llegar a esa primera instrucción una vez ya cargado excel como aplicacion (por ejemplo despues del durante el logotipo)

Lo que pasa es que me he dado cuenta que se ve la ultima hoja que se trabajo antes de guardar.(mientras inicia)

Como dije antes, a veces es micro segundos, pero a veces es mas. Luego ya empieza normalmente en el codigo del proyecto....

Share this post


Link to post
Share on other sites

Bueno eso ya es un proceso normal de excel y el inicio depende de los recursos que este usando tu computadora en ese momento, por eso puede variar, y claro al inicio se ve la última hoja en la que estabas cuando guardaste el libro, si tu macro al ejecutarse cambia de hoja pues veras por un instante la última hoja abierta y después cambiará a la que indicaste en tu macro.

Claro es más notorio cuando en tu código hay instrucciones como .Select o .Activate, las cuales son totalmente prescindibles y yo no recomiendo usar.

En resumen no hay forma de evitar ese parpadeo inicial puesto que los eventos de Workbook_Open se ejecutan después de toda la carga del excel. (Al menos que yo sepa)

Saludos 

Share this post


Link to post
Share on other sites
Hace 7 horas, AlexanderS dijo:

Bueno eso ya es un proceso normal de excel y el inicio depende de los recursos que este usando tu computadora en ese momento, por eso puede variar, y claro al inicio se ve la última hoja en la que estabas cuando guardaste el libro, si tu macro al ejecutarse cambia de hoja pues veras por un instante la última hoja abierta y después cambiará a la que indicaste en tu macro.

Claro es más notorio cuando en tu código hay instrucciones como .Select o .Activate, las cuales son totalmente prescindibles y yo no recomiendo usar.

En resumen no hay forma de evitar ese parpadeo inicial puesto que los eventos de Workbook_Open se ejecutan después de toda la carga del excel. (Al menos que yo sepa)

Saludos 

Gracias.

Algo asi me esperaba. Solo queria confirmar con personas mas expertas. 

Por cierto, ¿que alternativas me sugieres al Select o Activate?...

 

 

Share this post


Link to post
Share on other sites
Hace 4 horas, Mauricio_ODN dijo:

Hola @JDG

Es posible que la instrucción por evento Workbook_BeforeClose te ayude en algo, solo como sugerencia.

Sigo atento.

@AlexanderS siempre es un gusto leerte y compartir Master.

A veces pensé que por ahi iban los tiros. Hasta ahora he probado las combinaciones de codigo al respecto dentro del before pero cuando creo que lo he conseguido resulta que no.

Gracias por tu sugerencia.

Share this post


Link to post
Share on other sites

@JDGNo se será que lo que necesitas es así??

Private Sub Workbook_Open()
'Apertura
With Hoja1
uf = Hoja1.Cells(Rows.Count, "A").End(xlUp).Row
Hoja1.Range("A" & uf + 1) = Now
End With
End Sub

Private Sub Workbook_BeforeClose(Cancel As Boolean)
'Cierre
With Hoja1
uf = Hoja1.Cells(Rows.Count, "A").End(xlUp).Row
Hoja1.Range("B" & uf) = Now
'Tiempo de uso
Hoja1.Range("C" & uf) = Hoja1.Range("B" & uf) - Hoja1.Range("A" & uf)
End With
End Sub

Eso es lo que te están indicando Mauricio_ODN y AlexanderS

Pero le he puesto unos toque adicionales, es decir que al abrir se registra el tiempo de apertura del archivo, al salir te registra el tiempo de cierre y además se calcula el tiempo de uso.

Si te sirve, espero el Sandwich que ponen aqui abajo,  para todos los aquí participantes

 

Edited by Visor

Share this post


Link to post
Share on other sites

Oye!!!! esta genial este código. Me lo guardo para analizarlo y aprender algo mas despues...Si señor.

Sin embargo, yo creo que lo que yo quería no se va a poder hacer, tal y como me comenta Alexanders "es un proceso normal"....

Para que me entiendas, me refiero a todo lo que sucede desde que le haces clic al archivo para abrir hasta que empieza en tu código (por ejemplo) en el Private sub workbook_open ().

De todas formas muchas gracias por tu aporte.

 

 


 

Share this post


Link to post
Share on other sites
Hace 2 horas, Mauricio_ODN dijo:

Hola de nueva cuenta @JDG

Solo para no quedarme con la curiosidad, ¿me puedes compartir una muestra de tu archivo?

Gracias.

Que parte del codigo quisieras ver?.... es un poco complicado completo por el contenido de la Base de datos.

Share this post


Link to post
Share on other sites

Hola de nuevo @JDG, gracias a por la respuesta.

Solo era una muestra del archivo, no completo, si es que te fuera posible, para poder hacer pruebas con los eventos.

Pero si no es posible, no te preocupes.

Lo dejamos así.

 

Share this post


Link to post
Share on other sites

amigo @JDG, yo creo que los tiros van por donde comenta el amigo @Mauricio_ODN

Cita

Es posible que la instrucción por evento Workbook_BeforeClose te ayude en algo, solo como sugerencia.

la idea es que justo antes de cerrar y guardar tu archivo, posiciones tu archivo en la hoja que quieres que se vea al abrir nuevamente el archivo (por ejemplo una hoja menú), y así evitas lo que dices

suerte

Share this post


Link to post
Share on other sites
Hace 5 horas, bigpetroman dijo:

amigo @JDG, yo creo que los tiros van por donde comenta el amigo @Mauricio_ODN

la idea es que justo antes de cerrar y guardar tu archivo, posiciones tu archivo en la hoja que quieres que se vea al abrir nuevamente el archivo (por ejemplo una hoja menú), y así evitas lo que dices

suerte

Gracias por tu aporte, pero de momento eso es lo que tengo hecho con una hoja maximizada y de color sin lineas haciendo de fondo, pero esa no es mi intencion. Resumiendo es que fuera directamente e inmediatamente a un userform que es el que tengo como menu del "sistema"...

Un saludo.

Edited by JDG

Share this post


Link to post
Share on other sites
En 4/7/2020 at 0:42 , JDG dijo:

Gracias por tu aporte, pero de momento eso es lo que tengo hecho con una hoja maximizada y de color sin lineas haciendo de fondo, pero esa no es mi intencion. Resumiendo es que fuera directamente e inmediatamente a un userform que es el que tengo como menu del "sistema"...

Un saludo.

Hola, como ya te han comentado, no se puede evitar ver la presentación propia de Excel,  no hay forma de evitarla así se usen macros o cualquier evento del archivo, claro, dependiendo del tamaño del  archivo y/o las características de la PC y/o lo que tengas en tu evento Open, se verá menos o más tiempo. Para terminar, por más que actives tu Userform a través del  evento Open y quites la visibilidad del Excel, igual se verá la dichosa presentación, y no,  tampoco hay forma de mostrar directamente el Userform ¿Por qué? Excel es una hoja de cálculo, no es un Entorno de Desarrollo Integrado (IDE) con el que se crea software propio, el VBA es parte de Excel, no se puede compilar aparte, si quieres algo propio,  necesariamente tienes que recurrir a Visual.Net, C++, C, C#,  etc. Saludos. 

Share this post


Link to post
Share on other sites

Muchisimas gracias Abraham, de verdad. Me das luz en el tema.

Ademas, desde hace tiempo estoy pensando en adentrarme en el mundo de Visual.net. ¿cual es tu opinion?...

Share this post


Link to post
Share on other sites

Si quieres tus propios ejecutables y administrar/usar bases de datos, sí VB.Net; otra opción es C#. Ah bueno, si estás loco por la programación como yo, aprende C++ jejeje. Para cualquiera de los tres, descárgate Visual Studio, las ediciones Community de Microsoft son gratuitas. Saludos.

Share this post


Link to post
Share on other sites
Hace 3 horas, avalencia dijo:

Si quieres tus propios ejecutables y administara/usar bases datos, sí VB.Net; otra opción es C#. Ah bueno, si estás loco por la programación como yo, aprende C++ jejeje. Para cualquiera de los tres, descárgate Visual Studio, las ediciones Community de Microsoft son gratuitas. Saludos.

Gracias, asi haré.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

INFORMACIÓN BÁSICA SOBRE PROTECCIÓN DE DATOS

Responsable: Sergio Andrés Celemín

Finalidad: Moderar y responder comentarios de usuarios. Recuerda que la información que facilites es pública, y los datos que incluyas los leerá cualquier visitante de esta web, así como el avatar que poseas.

Legitimación: Consentimiento del interesado.

Destinatarios: Hetzner Online GmbH.

Derechos: Puedes ejercitar en cualquier momento tus derechos de acceso,
rectificación, supresión, oposición y demás derechos legalmente establecidos a
través del email sergio@ayudaexcel.com.

Información adicional: Encontrarás más información en la política de privacidad.




  • Posts

    • Continuando Adjunto una planilla ejemplo   FormatoCelda.xlsm
    • Buen día Luis Caballero Tenemos la maldita costumbre de cometer errores al solicitar ayuda, no soy la excepción, en realidad cuando puse Ej. 001-001-0012356, era nada mas un ejemplo, nuevamente me disculpo, porque podría ser cualquier número en realidad Ej. 002-003-0215489. o bien 018-003-0236546  y otra cosa es que podría tener no solo algunas filas, si varias, es decir varios registros Desde ya agradezco tu tiempo
    • Generar PDF y guardar en la carpeta PDF si un usuario(M4 es la celda donde voy copiar el nombre de usuario) le vuelvan a generar un PDF en un rango de = 7 días atrás mande un mensaje: usuario ya fue generado copia y fecha cuando fue creado, eso es todo lo que necesito hacer y no esta contraseña mi proyecto vuelvo a adjuntarlo. Feedback Formal-MACRO-PDF-1.rar
    • Hola Luis, Gracias por tu tiempo. Tienes razon. Estoy intendando de automatizar un cuadrante de turnos que cubra los 3 turnos de mañana, tarde y noche en la cual la cuarta persona tendra descanso. En el documento adjunto hay 2 tablas. Una nombrada "automatica" y otra nombrada "manual". Trato de hacer una combinacion de letras en la cual el reparto seria por cada fila asi: Parto de la columna base que es la columna "E" y si la letra es: "F" (fiesta), las otras columnas deben de ser M; T; y N (se refiere a cubrir 3 turnos, mañana, tarde y noche). A partir de aqui se hace todas las combinaciones posibles entre las letras: M; T; N; F; P; V; B Ahora no se que en que medida este se puede aplicar viceversa la asignacion de letras entre las otras columnas, quiero decir de que si en un momento dado necesito cambiar la letra en la columna "G" por cualquier letra me haga el reparto entre las otras coulmnas. Te adjunto un pantallazo y el documento de nuevo Si te fijas en la tabla "AUTOMATICO" en la fila 7 y 8 cambian las reglas. Las corectas estan en la tabla "MANUAL". Gracias y perdona por las molestias. Saludos, FORMULA FUNCCION SI - 2.xlsx
    • prueba con esta macro cambiacontenidocelda.xlsm
  • Recently Browsing

    No registered users viewing this page.

×
×
  • Create New...

Important Information

Privacy Policy