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

VBScript Discussion :

Poursuivre script si erreur


Sujet :

VBScript

  1. #1
    Membre habitué Avatar de guenfood
    Homme Profil pro
    Webdesigner
    Inscrit en
    Janvier 2004
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2004
    Messages : 255
    Points : 126
    Points
    126
    Par défaut Poursuivre script si erreur
    Bonsoir,

    J'ai le script ci-dessous qui me permet de récupérer tous les comptes users présents dans C:\utilisateurs sur un parc de machine (dans un fichier Computer_list.csv)
    Le problème est que si le pc est éteint ou déconnecté du réseau au moment où le script se lance, celui-ci s'arrête.

    Que dois-je rajouter, et où, pour que le script continue de fonctionner si un pc est éteint ?

    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
    31
    32
    33
    Dim oFilesys
    computerlist_path = "computer_list.csv"
    ResultFile = "result.csv"
     
    Set oFilesys = CreateObject("Scripting.FileSystemObject")
     
    '### création objet fichier sortie ###
    Set oFiletxt = oFilesys.CreateTextFile(ResultFile,True)
       oFiletxt.WriteLine "Machine;Dossier Profile;Path"
     
    Set Ws = CreateObject("Wscript.Shell")
    Set stdout = oFilesys.GetStandardStream (1)
     
    '### ouverture du fichier liste computer ###
    set readfile = oFilesys.OpenTextFile(computerlist_path, 1, false) 
     
    do while readfile.AtEndOfStream=false 
    str_computer = readfile.ReadLine 
     
    if (left(str_computer,1) = "#" ) then
    else
     
    '### accès au dossier users de la machine via partage c$ ###
    Set fsoFolder = CreateObject("Scripting.FileSystemObject")
    Set folder = fsoFolder.GetFolder("\\" & str_computer & "\c$\users")
    Set subfolders = folder.SubFolders
    for each objFolder in subfolders
       oFiletxt.WriteLine str_computer & ";" & objFolder.Name & ";" & objFolder.Path
    next    
     
    end if
     
    loop
    Merci par avance pour votre aide.

  2. #2
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 417
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 417
    Points : 5 816
    Points
    5 816
    Par défaut
    Bonjour;

    - Il fallait indiquer le message d'erreur et la ligne correspondante.
    - Pour plus de clarté, les variables utilisées devraient être déclarées pour éviter toute confusion.
    - Une bonne indentation du code permet une bonne compréhension
    - La variable stdout a été initialisée mais elle n'a été utilisée nulle part dans le code. A quoi sert-elle ?
    - Un seul objet FileSystemObject aurait suffi pour le traitement, on n'a pas besoin d'en créer 2 ou plus.
    - Dans la boucle Do While, Il y a création, inutilement, d'un grand nombre d'objets FileSystemObject.
    Voici une ébauche du 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
    31
    32
    33
    34
    35
    36
    37
    Option Explicit 
     
    Const ForReading = 1, ForWriting = 2
    Const computerlist_path = "computer_list.csv"
    Const ResultFile = "result.csv"
    Dim oFilesys, oFiletxt, WS, stdout, readfile, str_computer,  oFolder, oSubfolders, objFolder
     
    Set oFilesys = CreateObject("Scripting.FileSystemObject")
     
    '### création objet fichier sortie ###
    Set oFiletxt = oFilesys.CreateTextFile(ResultFile, True)
    oFiletxt.WriteLine "Machine;Dossier Profile;Path"
     
    Set WS = CreateObject("Wscript.Shell")
    Set stdout = oFilesys.GetStandardStream(1)  '  ??????
     
    '### ouverture du fichier liste computer ###
    Set readfile = oFilesys.OpenTextFile(computerlist_path, ForReading, False) 
     
     'On Error Resume Next
     
    Do While Not readfile.AtEndOfStream 
        str_computer = readfile.ReadLine 
        If left(str_computer, 1) <> "#"  Then
           '### accès au dossier users de la machine via partage c$ ###
            If Err.Number <> 0 Then 
               MsgBox "Erreur n° " & Err.Number & "   Desc : " & Err.Description
               Err.Clear
            End If
            Set oFolder = oFilesys.GetFolder( "\\" & str_computer & "\c$\users")
            Set oSubfolders = oFolder.SubFolders
            For Each objFolder In oSubfolders
               oFiletxt.WriteLine str_computer & ";" & objFolder.Name & ";" & objFolder.Path
            Next    
            On Error GoTo 0 
        End If
    Loop

  3. #3
    Membre averti
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Novembre 2011
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Novembre 2011
    Messages : 163
    Points : 304
    Points
    304
    Par défaut
    Bonjour,

    Pour ma part, je gère le souci via un test d'accessibilité des machines :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub online
    Set objPing = GetObject("winmgmts:{impersonationLevel=impersonate}!\\").ExecQuery("select * from Win32_PingStatus where address = '" & str_computer & "'")
    For Each objStatus in objPing
    If objStatus.Statuscode = 0 Then inaccessible = 1 else inaccessible = 0
    Next
    End Sub
    Avec juste l'appel de fonction et un test à ajouter sur ton script (ligne 23 et 24) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    call online
    If left(str_computer, 1) <> "#" and inaccessible = 0 Then
    ++

  4. #4
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 417
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 417
    Points : 5 816
    Points
    5 816
    Par défaut
    Citation Envoyé par Cachlab Voir le message
    Pour ma part, je gère le souci via un test d'accessibilité des machines
    Très bonne idée.
    Moi, je transformerais la sub en fonction booléenne et je l'appellerais pour pour chaque PC.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Function OnLine(strComputer)
       Set objPing = GetObject("winmgmts:{impersonationLevel=impersonate}!\\").ExecQuery("select * from Win32_PingStatus where address = '" & strComputer & "'")
       For Each objStatus in objPing
         OnLine = (objStatus.Statuscode = 1)
       Next
    End Function
    et la ligne 24 devient : If Left(str_computer, 1) <> "#" And OnLine(str_Computer) Then.

Discussions similaires

  1. Script bash Erreur une fois mis en page
    Par kazylax dans le forum Linux
    Réponses: 4
    Dernier message: 01/05/2009, 13h56
  2. Script VB : Erreur "COM class factory"
    Par hedgehog dans le forum Windows
    Réponses: 0
    Dernier message: 25/11/2008, 21h19
  3. premier script, premiere erreur
    Par rstadel dans le forum Langage
    Réponses: 7
    Dernier message: 28/09/2008, 13h53
  4. script avec erreurs
    Par pfrib dans le forum C
    Réponses: 3
    Dernier message: 27/07/2006, 23h36
  5. Script en erreur
    Par Elois dans le forum Langage SQL
    Réponses: 3
    Dernier message: 20/04/2004, 15h46

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