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 :

Utilisation simultanée de plusieurs classeurs.


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Inscrit en
    Juillet 2006
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 38
    Points : 22
    Points
    22
    Par défaut Utilisation simultanée de plusieurs classeurs.
    Bonjour à tous,

    Je réalise actuellement un projet avec un gros classeur principal, auquel est lié un classeur secondaire, dont le (seul) but est de récupérer les informations cruciales du principal, et de les exporter au format CSV de façon périodique (toutes les 5 secondes en l'occurence, et un programme externe exporte ça sur un FTP).

    Mon classeur secondaire comporte donc une macro de ce genre-là, écrite dans "ThisWorkbook".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub periodicExportStart()
        exportCSV
        If Range("SExportOnOff").Cells(1, 1) = 1 Then 'si export activé
            Application.OnTime Now + TimeValue("00:00:05"), "ThisWorkbook.periodicExportStart"
        End If
    End Sub
    Jusque là, quand seul le classeur secondaire est ouvert, tout marche bien. Par contre, quand j'ouvre en plus le classeur principal et que je lui donne le focus (pour travailler dedans tout simplement), le code plante, parce qu'il ne reconnaît plus les plages de données (comme "SExportOnOff" par exemple dans le code que j'ai donné).

    Je sais que je peux résoudre le problème en réunissant mes deux classeurs en un seul, mais ça me semble peu judicieux, et, surtout, j'aimerais comprendre d'où vient le problème !

    Merci de vos réponses !

  2. #2
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Bonjour,

    Il est préférable de spécifier sur quel classeur on travail sinon le code se place sur le classeur actif
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub periodicExportStart()
        exportCSV
        If Thisworkbook.Range("SExportOnOff").Cells(1, 1) = 1 Then 'si export activé
            Application.OnTime Now + TimeValue("00:00:05"), "ThisWorkbook.periodicExportStart"
        End If
    End Sub
    Jérôme

  3. #3
    Membre à l'essai
    Inscrit en
    Juillet 2006
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 38
    Points : 22
    Points
    22
    Par défaut
    Ah, c'était un stupidissime oubli de ma part...

    Merci pour la réponse en tout cas

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

Discussions similaires

  1. [XL-2000] Utiliser projet dans plusieurs classeurs
    Par Carambar dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 09/10/2009, 15h03
  2. Recherche simultanée dans plusieurs classeurs
    Par Bomba dans le forum Excel
    Réponses: 1
    Dernier message: 19/04/2008, 00h08
  3. Réponses: 2
    Dernier message: 24/10/2007, 20h26
  4. [Syntaxe] Action simultanée sur plusieurs élements
    Par FranT dans le forum Composants VCL
    Réponses: 2
    Dernier message: 20/03/2003, 20h20
  5. [VB6] Utiliser un ou plusieurs datareports ?
    Par SpaceFrog dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 21/11/2002, 10h44

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