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

VB.NET Discussion :

Problème de synchronisation Excel / VB.net


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 2
    Par défaut Problème de synchronisation Excel / VB.net
    Bonjour,

    J'ai installé dans mon Excel un plugin (propriétaire) qui définit de nouvelles formules dans Excel. Dans une case, je peux par exemple taper :
    J'obtiendrai le résultat désiré.

    Je suis maintenant en train de développer une application qui crée un Excel et cherche à obtenir le résultat de certaines de ces formules.

    Je rencontre un souci : les formules ne sont pas instantanées et mon VB.net "rate" certains résultats.

    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    sheet.Range("A1").Formula = "=maFormule()"
    libelle = Convert.ToString(sheet.Range("A1").Value())
    Ce code va me retourner une chaine vide, alors qu'au bout d'un certain temps =maFormule() va effectivement retourner une valeur (que je vois quand j'affiche mon Excel).

    Si je mets un timer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.Threading.Thread.Sleep(1000)
    le code se met à fonctionner parfaitement mais...
    1. Je ne trouve pas ça très joli
    2. Ce n'est pas très robuste (si une formule met plus de temps à se calculer)
    3. C'est beaucoup plus lent que de continuer dès qu'Excel a fini son traitement


    Quelle serait la bonne méthode à adopter ? Puis-je savoir si mon Excel est actuellement en calcul ? Puis-je savoir si une cellule est "rafraichie" ?

    Merci pour votre aide.

  2. #2
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 2
    Par défaut
    Bonjour,
    J'ai trouvé une solution de contournement pas trop horrible qui consiste à mettre "Waiting..." dans toutes les formules. Je mets ensuite les formules à jour et dès que je n'ai plus de "Waiting..." dans mes cases c'est que j'ai fini le calcul :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
        Private Sub WaitForResultOrTimeout(Optional ByVal range As String = "A1")
            Dim current, beginning As Integer
            current = Environment.TickCount
            beginning = Environment.TickCount
     
            'Tant qu'il reste des éléments "Waiting..."
            While (Not sheet.Range(range).Find(WAITING, , Excel.XlFindLookIn.xlValues) Is Nothing) _
                    AndAlso ((current - beginning) < My.Settings.SearchTimeout)
                Application.DoEvents()
                System.Threading.Thread.Sleep(WAIT)
                current = Environment.TickCount
            End While
        End Sub
    Je reste preneur d'une solution plus élégante.
    Merci.

Discussions similaires

  1. Problème OLEAutomation Excel entre .NET 3.5 et .NET4
    Par feanor91 dans le forum VB.NET
    Réponses: 8
    Dernier message: 01/10/2013, 16h05
  2. Réponses: 8
    Dernier message: 20/07/2010, 12h25
  3. [PPT-2007] Problème de synchronisation Excel\powerpoint !
    Par Rapheux dans le forum Powerpoint
    Réponses: 0
    Dernier message: 04/11/2009, 15h46
  4. [Apache Commons Net] Problème de synchronisation FTP
    Par Traroth2 dans le forum API standards et tierces
    Réponses: 4
    Dernier message: 15/09/2008, 18h19
  5. [VB.net] Problème de synchronisation d'une base
    Par WriteLN dans le forum Windows Forms
    Réponses: 18
    Dernier message: 21/10/2005, 13h11

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