IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

PageSetup: exécution longue


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    817
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 817
    Par défaut PageSetup: exécution longue
    Bonjour,

    La mise en page pour impression utilise la commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        With ActiveSheet.PageSetup
    cependant le traitement est extrèmenent long, au point de croire que la macro est palntée.
    exsite il une autre façon de gérer les mise en page pour impression ?

    Merci

    Denis

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 141
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    C'est exact que le temps d'exécution est long mais il suffit d'enlever toutes les méthodes et propriétés dont tu n'as pas l'usage.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Expert confirmé
    Avatar de Oliv-
    Homme Profil pro
    solution provider
    Inscrit en
    Mars 2006
    Messages
    4 093
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : solution provider

    Informations forums :
    Inscription : Mars 2006
    Messages : 4 093
    Billets dans le blog
    20
    Par défaut
    SAlut,
    J'avais rencontré ce pb où avec certaines imprimantes le temps de traitement était multiplié.

    Pour contourner ce pb j'ai ajouté une imprimante simple/basique sur les postes de travail (espon lq850)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Old_imp = Application.ActivePrinter
    Application.ActivePrinter = "Epson LQ-850 sur LPT1:"
     
     
    ' TON CODE
     
    Application.ActivePrinter =Old_imp
    Have a nice day. Oliv'
    Votre réponse est peut être dans mon blog !
    https://www.developpez.net/forums/blogs/191381-oliv-/

  4. #4
    Membre extrêmement actif
    Avatar de NVCfrm
    Homme Profil pro
    Administrateur Système/Réseaux - Developpeur - Consultant
    Inscrit en
    Décembre 2012
    Messages
    1 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur Système/Réseaux - Developpeur - Consultant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 037
    Billets dans le blog
    5
    Par défaut
    bonjour,
    pour ne pas exécuter toujours la configuration de l'imprimante dans le code à chaque impression, un test m'évite cela:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    t = ActiveSheet.PageSetup.PrintArea = "$E$8:$H$30"
    If t Then
       MySheet.Range("$E$8:$H$30").PrintOut
    Else
       conFigurer(MySheet.Name,Range("$E$8:$H$30"))
    End if
     
    Sub Configurer(sh as String, imprimer as Range)
    ......
    .....
    End Sub
    dans le cas de plusieurs utilisateurs la plage d'impression peut être rendu inaccessible. les données y seront apportées par code.

  5. #5
    Membre Expert
    Avatar de tototiti2008
    Homme Profil pro
    Formateur/développeur
    Inscrit en
    Octobre 2008
    Messages
    1 099
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Formateur/développeur

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 099
    Billets dans le blog
    2
    Par défaut
    Bonsoir à tous,

    une autre possibilité est de faire la mise en page avec les macros XL4
    http://www.mcgimpsey.com/excel/udfs/pagesetup.html
    Mais bon, on ne sait pas si ça sera encore fonctionnel encore longtemps (je ne sais pas ce qu'il en est sur Excel 2013)

Discussions similaires

  1. [ZF 1.8] Exécution longue d'une page
    Par eMeRiKa dans le forum Zend Framework
    Réponses: 2
    Dernier message: 24/03/2010, 18h59
  2. Exécution trop longue d'une requête
    Par lodan dans le forum Requêtes
    Réponses: 5
    Dernier message: 13/10/2006, 15h34
  3. CGI exécution trop longue
    Par crochepatte dans le forum Web
    Réponses: 6
    Dernier message: 23/08/2006, 15h11
  4. CGI exécution trop longue
    Par crochepatte dans le forum Apache
    Réponses: 3
    Dernier message: 18/08/2006, 15h02
  5. Requete trop longue à exécuter
    Par fguilbert dans le forum Requêtes
    Réponses: 2
    Dernier message: 29/06/2006, 10h33

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo