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 :

Macro mise à jour de liens sur des classeurs externes (excel)


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2007
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 18
    Points : 17
    Points
    17
    Par défaut Macro mise à jour de liens sur des classeurs externes (excel)
    Bonsoir à tous !
    J'essaye actuellement de mettre au point un classeur excel (DP) réparti en plusieurs onglets (1-2-3-4-5-6) avec une macro qui serait à même d'aller chercher les données liées (également sur des classeurs excel) au classeur (DP). Il y a environ 30-40 liens à mettre à jour pour les onglets 2-3-4.
    J'avais pu mettre en oeuvre une solution il y a quelques mois, mais lorsque j'ai voulu la réactiver, celle-ci provoque une erreur que je n'arrive pas à solutionner...
    N.B. Le classeur est au préalable déprotégé par une macro, c'est la deuxième étape où les choses se gâtent...
    A la fin de ma mise à jour, j'aimerais que l'affichage revienne sur un onglet défini (2), mais actuellement je sèche...
    Si quelqu'un a la solution miracle, je suis preneur... (J'ai déjà des cheveux en moins...).
    Bonne soirée à tous !
    Didier
    Fichiers attachés Fichiers attachés

  2. #2
    pgz
    pgz est déconnecté
    Expert éminent Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Points : 6 591
    Points
    6 591
    Par défaut
    Bonjour.

    Voici qq idées pour simplifier ton code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    Sub MiseAJour()
    Dim wbk As Excel.Workbook
     
    'instanciation
    Set wbk = Application.ThisWorkbook
     
    ' Déprotection
        wbk.Unprotect
        For i = 1 To 5
            wbk.Sheets(i).Activate
            wbk.Sheets(i).Unprotect
        Next i
     
    ' Mise à jour
        wbk.UpdateLink wbk.LinkSources
     
    ' Reprotection
        For i = 1 To 5
            wbk.Sheets(i).Activate
            wbk.Sheets(i).Protect
        Next i
        wbk.Protect
     
    'activation feuille 2
        wbk.Sheets(2).Activate
     
    'libération
    Set wbk = Nothing
     
    End Sub
    Bon courage,

    PGZ
    pluritas non est ponenda sine necessitate - Le rasoir d'Okham
    Ne jamais attribuer à la malignité ce que la stupidité peut expliquer -Le rasoir d'Hanlon

  3. #3
    Membre à l'essai
    Inscrit en
    Octobre 2007
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 18
    Points : 17
    Points
    17
    Par défaut Macro mise à jour
    Salut Pgz,
    Merci pour le tuyau, nickel chrome !
    Didier


+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 0
    Dernier message: 17/03/2015, 12h40
  2. Réponses: 3
    Dernier message: 12/01/2015, 20h43
  3. Réponses: 1
    Dernier message: 27/06/2007, 10h31
  4. Réponses: 17
    Dernier message: 15/10/2003, 01h45

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