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

Excel Discussion :

Inhiber la fenêtre DOS sur commande .exec (VBA)


Sujet :

Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Avril 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Avril 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Inhiber la fenêtre DOS sur commande .exec (VBA)
    Bonjour,

    Je sais qu'il y a eu beaucoup de questions sur ce sujet, mais je n'arrive à trouver LA solution.

    Voilà mon problème. J'ai 740 adresses IP à scanner en ping. Certaine "bagotte" (c'est pour cela que je n'utilise pas le Win32_PingStatus, car je désire avoir le nombre de paquets perdus)
    Ainsi sur Excel j'ai un tableau avec mes adresses IP et le nom de l'équipement. Je fais ainsi un boucle VBA sur chaque ligne.

    Voici le code dans ma boucle :
    Set objShell = CreateObject("WScript.Shell")
    Set objScriptExec = objShell.Exec("cmd /c ping -n 5 -w 1000 " & Host)

    strPingResults = LCase(objScriptExec.StdOut.ReadAll)

    toto = InStr(strPingResults, "perdus =")
    'code pour avoir que le "= X" ou X est le nombre de perte
    toto = Left(Left(RTrim(Mid(strPingResults, toto + 6)), Len(RTrim(Mid(strPingResults, toto + 6))) - 1), 4)
    toto = Trim(toto)
    strResult = "Ping OK (perte de paquet" & toto & "/5)"

    Ainsi mon problème est qu'il exécute la fenêtre DOS. J'aimerai la masquer afin de pouvoir continuer à travailler sur autre chose. Cela met tout de même 1h pour les 740 adresses.
    J'ai ainsi vu le .RUN : objShell.Run("cmd /c ping -n 5 -w 1000 " & Host,0,true)

    Seulement je n'arrive à retourner le résultat. J'ai tout essayé (du moins je pense). Ma variable objScriptExec (object) ne fonctionnant pas, je l'ai passé en string. Mais la valeur me retourne 0 avec le .run

    Avez-vous une solution? Merci à tous.

  2. #2
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Avril 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Avril 2014
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    up please

Discussions similaires

  1. [VB6] Lire et écrire sur une fenêtre dos...
    Par Zenar dans le forum VB 6 et antérieur
    Réponses: 14
    Dernier message: 16/03/2008, 13h14
  2. Question sur la fenêtre DOS
    Par Madguitar63 dans le forum Général Python
    Réponses: 4
    Dernier message: 31/03/2007, 14h12
  3. commande dos sur lecteur reseau
    Par allstar dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 28/03/2007, 18h52
  4. Réponses: 1
    Dernier message: 01/02/2007, 12h51
  5. Réponses: 3
    Dernier message: 05/09/2005, 14h09

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