Saltar al contenido

Como controlar la apertura de excel?


Recommended Posts

publicado

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.

publicado

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....

publicado

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 

publicado
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?...

 

 

publicado
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.

publicado

@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

 

publicado

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.

 

 


 
publicado
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.

publicado

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í.

 

publicado

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

publicado
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.

publicado
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. 

publicado

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?...

publicado

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.

publicado
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é.

Archivado

Este tema está ahora archivado y está cerrado a más respuestas.

  • 109 ¿Te parecen útiles los tips de las funciones? (ver tema completo)

    1. 1. ¿Te parecen útiles los tips de las funciones?


      • No
      • Ni me he fijado en ellos

  • Current Donation Goals

    • Raised 0.00 EUR of 130.00 EUR target
  • Archivos

  • Estadísticas de descargas

    • Archivos
      187
    • Comentarios
      97
    • Revisiones
      28

    Más información sobre "Un juego del Rabino en Excel"
    Última descarga
    Por pegones1

    1    1

  • Crear macros Excel

  • Mensajes

    • Hola nuevamente. Por eso la importancia de lo que mencionas tú como "ruta relativa". Tal cual comentas, y aún sin llegar a algunos detalles importantes para ayudarte, en realidad tal cual te comenté le día miércoles, pues sí podías hacer como comentabas, era cosa de obtener los Id de Windows (como tú los llamas) y la ruta de OneDrive en casa usuario y eso sí se puede obtener con VBA y luego pasarlo a PQ, pero medio que te cerraste en que "PQ no puede trabajar con rutas relativas", cosa cierta pero siempre hay formas. Si SAP puede o no guardar en OneDrive o SharePoint, pues si está mapeado en la PC ¡claro que se puede! Pero bueno, creo que si te es útil tu propia propuesta ¡avanza con eso!
    • Perdona @Abraham Valencia pero he estado liado estos días. En realidad todo el problema se reduce a estos dos problemas: Problema 1: El script que "fabrica" SAP y que luego "pego" en la macro, no es capaz de  guardar archivos en SharePoint. He estado buscando, y en realidad muchas personas tienen ese problema (no poder guardar un Excel en SAP a través de VBA). Eso muy probablemente sean problemas de permisos, que no puedo cambiar (no soy administrador de nada). Como no puedo solucionarlo así, paso al plan B, que es guardar en Excel que me genera SAP en el ordenador de cada usuario que ejecute la plantilla (y que sí está guardada en SharePoint), para después con PowerQuery llamar a ese Excel (el export). Para ello, pretendo guardar el export, en la ruta relativa "C:\..\..\..\OneDrive - NombreEmpresa\Documentos\SAP\SAP GUI" donde los \..\..\..\ saltan las rutas personales de cada usuario (tipo C:\users\IDusuario\). Eso lo hace bien, y el archivo se guarda en la ruta de cada usuario que lo usa, pero surge el problema 2 Problema 2: PowerQuery no trabaja con rutas relativas del tipo  "C:\..\..\..\OneDrive - NombreEmpresa\Documentos\SAP\SAP GUI" necesita que sea del tipo fija "C:\users\IDusuario\OneDrive - NombreEmpresa\Documentos\SAP\SAP GUI" pero claro, IDusuario es diferente para cada usuario.   Pero escribiendo todo esto, creo que he dado con una posible solución, no grabar el export en una ruta de usuario, sino en una en la raiz de C:, que siempre será igual para todos los usuarios, del tipo C:\Sap\export.xlsx que seria igual en todos los ordenadores. Asi sí podría decirle a PowerQuery que vaya siempre a la ruta C:\Sap\ que existirá en todos los ordenadores. Mañana intentaré hacer pruebas, aunque mi solución ideal seria que se pudiera guardar en el SharePoint. Saludos.
    • Hola La opción brindada por @torquemada es correcta, funciona, pero hay algunos inconvenientes que (desde mi punto de vista) no la convierten en mi primera elección. Los inconvenientes son: Tendrías que ir columna por columna haciendo los reemplazos, claro que no se harían a mano sino que utilizarías la opción reemplazar o la opción texto en columnas, aun asi demorará un poquito y será trabajoso. Cada vez que descargues otro listado, tendrás que volver a realizar los reemplazos. Me parece una mejor propuesta lo siguiente: Descarga los movimientos a un archivo de Excel Desde tu control de pagos (otro archivo) cargas los movimientos del archivo descargado mediante Power Query Power Query hará los reemplazos y reconocerá todo correctamente (sin que tengas que hacer nada especial) Cuando descargues los movimientos un día posterior, solamente tendrás que hacer clic en "Actualizar" y todo funcionará en automático
    • Hola a todos, Efectivamente, me temo que tal como trabajan las funciones =HOY() y/o =AHORA() (volátiles), sólo con macros puedes obtener soluciones. Un recurso pedestre podría ser, cada vez que quieras que se fije un dato, te sitúes en esa celda y pulses F2, F9 e INTRO.  Pero claro, puede ser un inconveniente si hay que hacerlo repetitivamente en muchas ocasiones,.............. en fin, lo comento sólo como posibilidad. Saludos,
    • Hola nuevamente, mi duda sigue siendo la ruta, o rutas, finales que quedan, esas que llamas "relativas"; igual por si acaso pon 3 o 4 de esas, tal cual son y/o se ven en el explorador de cada PC y, de ser posible, en cualquier otro "lado" en que las veas.
  • Visualizado recientemente

    • No hay usuarios registrado para ver esta página.
×
×
  • Crear nuevo...

Información importante

Echa un vistazo a nuestra política de cookies para ayudarte a tener una mejor experiencia de navegación. Puedes ajustar aquí la configuración. Pulsa el botón Aceptar, si estás de acuerdo.