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 :

Temporisation de lecture de fichier (texte) entre création/lecture [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Juin 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2017
    Messages : 3
    Par défaut Temporisation de lecture de fichier (texte) entre création/lecture
    Bonjour
    La macro a pour but de lancer le shell net view et stocker le résultat dans un fichier texte (crée sur un disque externe)
    puis ce fichier est lu par le classique get...
    - En pas à pas le fichier lu est renseigné sans problème.
    - En exécution la fréquence de résultats positifs est variable voire nulle.
    j'ai essayer de temporiser entre les deux étapes sans amélioration.
    Voila le mystère!!!

    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
     
    Option Explicit
    Public LectNetView As String
    Public ListDesDk As String
    Sub passe_EnvironRevueTest()
        Dim leClas, DossF As String
        Dim I, J, ResuN, ResuD, ManX, CtrVId, CtrOk
        I = 0
    Stadium:
        leClas = ThisWorkbook.Path & "\NetView"
        On Error Resume Next
        Kill leClas & "\envirOrdo.txt"
        RmDir leClas
        On Error GoTo 0
        If Dir(leClas, vbDirectory) = "" Then MkDir leClas
        leClas = leClas & "\envirOrdo.txt"
    I = 0
        Shell "cmd.exe /C c:\windows\system32\net view > " & "" & leClas & "", vbHide
     
        'Application.Wait (Now + TimeValue("0:00:02"))
    Relire:
        LectNetView = LireFichierTexte(leClas)
        I = I + 1
        If LectNetView = "" And I < 4 Then GoTo Relire
        If LectNetView <> "" Then Beep
        If LectNetView = "" Then
        CtrVId = CtrVId + 1
        Else
        CtrOk = CtrOk + 1
        End If
        J = J + 1
        If J > 100 Then Stop: J = 0: CtrVId = 0: CtrOk = 0: Stop
        GoTo Stadium
    End Sub
    Public Function LireFichierTexte(ByVal monfichier As String) As String
        On Error GoTo LireFichierTexteErreur
        Dim IndexFichier As Integer
        IndexFichier = FreeFile()
        Open monfichier For Binary Access Read As #IndexFichier
        LireFichierTexte = Space$(LOF(IndexFichier))
        Get #IndexFichier, , LireFichierTexte
        Close #IndexFichier
        Exit Function
    LireFichierTexteErreur:
        Close #IndexFichier
        LireFichierTexte = ""
    End Function
    Merci à tous les courageux
    RON

  2. #2
    Rédacteur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2013
    Messages
    1 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Août 2013
    Messages : 1 035
    Par défaut
    Attention car Shell est asynchrone, c'est-à-dire que le code VBA continue son travail sans attendre la fin de l'instruction Shell.
    Il faut donc soit s'assurer que l'instruction Shell est terminée, soit faire une temporisation assez longue.
    par exemple si tu détruis un fichier avec Shell (pourquoi pas ?) il faut boucler tant que Dir trouve encore le fichier à supprimer. Tu n'as pas ce problème si tu le détruit avec l'instruction Kill du VBA.
    Pour le reste je ne peux pas t'aider car je n'ai pas compris ce que tu fais exactement avec Shell.
    Bonne continuation.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Juin 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2017
    Messages : 3
    Par défaut [XL-2010] Temporisation de lecture de fichier (texte) entre création/lecture
    Citation Envoyé par laurent_ott Voir le message
    Attention car Shell est asynchrone, c'est-à-dire que le code VBA continue son travail sans attendre la fin de l'instruction Shell.
    Il faut donc soit s'assurer que l'instruction Shell est terminée, soit faire une temporisation assez longue.
    par exemple si tu détruis un fichier avec Shell (pourquoi pas ?) il faut boucler tant que Dir trouve encore le fichier à supprimer. Tu n'as pas ce problème si tu le détruit avec l'instruction Kill du VBA.
    Pour le reste je ne peux pas t'aider car je n'ai pas compris ce que tu fais exactement avec Shell.
    Bonne continuation.
    Attention car Shell est asynchrone bien sûr

    merci tu m'as remis dans le droit chemin
    Ron

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 05/03/2010, 18h15
  2. Probleme casse fichier texte avec création table SAS
    Par pierre24 dans le forum SAS Base
    Réponses: 4
    Dernier message: 16/05/2008, 10h52
  3. lecture de fichier texte
    Par prorider dans le forum C
    Réponses: 36
    Dernier message: 08/09/2004, 20h55
  4. Stockage de données & lecture d'un fichier texte
    Par petitours dans le forum C++Builder
    Réponses: 6
    Dernier message: 13/03/2004, 14h05
  5. Réponses: 6
    Dernier message: 23/12/2003, 15h30

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