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 :

VBA Comment passer un objet openTextFile en argument de procédure


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Automaticien
    Inscrit en
    Octobre 2019
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Octobre 2019
    Messages : 75
    Par défaut VBA Comment passer un objet openTextFile en argument de procédure
    Bonjour à tous,

    J'ai un script qui doit générer des fichiers textes ( un pour l'instant ), j'ai une partie qui se répète, donc je voudrais la mettre dans une procédure.
    Le tout sans fermer le fichier entre la procédure appelante et la procédure appelé.
    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
    Sub flecheGauche()
        Dim fs, i, derSynoptOfType, typeView, firstOfTypeView, path, chemin, fichier
        fichier = "scrpt_FlecheGauche.txt"
        chemin = "C:\expExcel\"
        path = chemin & fichier
        headNavFleche path
     
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set a = fs.opentextfile(path, 8, -2) ' 8 -> For Append, -2 -> TristateUseDefault
        typeView = "Synoptique"
        derSynoptOfType = DerviewUsed(typeView) 'position du dernier synoptique utilisé
        firstOfTypeView = firstTypeView(typeView)   ''position du premier synoptique utilisé
     
        '---     Appel de la procédure "chaqueTypeFlecheGauche(fso as object)
        chaqueTypeFlecheGauche a, typeView    -> Type d'argument ByRef incompatible
     
        a.Close
        Set a = Nothing
        Set fs = Nothing
     
    End sub
     
    '  Procédure de sélection des vues dans la navigation des vues
    Sub chaqueTypeFlecheGauche(b As Object, typeVue)
        While Range("T_Vues_Synopt_WinCC[type]").Item(i) = typeVue
            If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(i) = "oui" Then
                    b.writeline "Case " & Left(Range("T_Vues_Synopt_WinCC[Vues]").Item(i), 3)
                    For k = i - 1 To 1 Step -1
                        If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(k) = "oui" Then
                            b.writeline "                newView = " & Chr(34) & Range("T_Vues_Synopt_WinCC[Vues]").Item(k) & Chr(34)
                            Exit For
                        End If
                    Next k
            End If
            i = i + 1
        Wend
    End Sub
    Donc j'ai une erreur "Type d'argument ByRef incompatible".
    Je souhaitera ne pas à avoir à fermer le fichier avant l'appel de la procédure appelé, puis le ré ouvrir dans la procédure appelé.

    La partie à répéter est la boucle while.

    Je ne sais pas comment faire pour passer l'instance "a" du fichier ouvert dans la procédure appelé.
    Merci d'avance pour votre aide.

    ps: Et oui pour ceux qui ont deviné, j'essaie de générer mes scripts vbs pour WinCC avec Excel
    Le code complet:
    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
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    Dim posFirst, posLast
    Sub flecheGauche()
        Dim fs, i, derSynoptOfType, typeView, firstOfTypeView, path, chemin, fichier
        fichier = "scrpt_FlecheGauche.txt"
        chemin = "C:\expExcel\"
        path = chemin & fichier
        headNavFleche path
     
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set a = fs.opentextfile(path, 8, -2) ' 8 -> For Append, -2 -> TristateUseDefault
     
        'For i = 1 To UBound(Range("T_Vues_Synopt_WinCC[Vues]"))
     
        typeView = "Synoptique"
        derSynoptOfType = DerviewUsed(typeView) 'position du dernier synoptique utilisé
        firstOfTypeView = firstTypeView(typeView)   ''position du premier synoptique utilisé
     
        a.writeline "Case " & Left(firstOfTypeView, 3)
        a.writeline "                newView = " & Chr(34) & derSynoptOfType & Chr(34)
        i = 1 + posFirst
        '------     La partie qui va se répéter
        While Range("T_Vues_Synopt_WinCC[type]").Item(i) = typeView
            If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(i) = "oui" Then
                    a.writeline "Case " & Left(Range("T_Vues_Synopt_WinCC[Vues]").Item(i), 3)
                    For k = i - 1 To 1 Step -1
                        If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(k) = "oui" Then
                            a.writeline "                newView = " & Chr(34) & Range("T_Vues_Synopt_WinCC[Vues]").Item(k) & Chr(34)
                            Exit For
                        End If
                    Next k
            End If
            i = i + 1
        Wend
        '-----  Fin de la partie qui va se répéter
        a.writeline "Case Else" & Left(firstOfTypeView, 3)
        a.writeline "                newView = " & Chr(34) & firstOfTypeView & Chr(34)
        a.writeline "        End Select"
        a.writeline "    Case " & Chr(34) & "Compteurs" & Chr(34)
        a.writeline "        Select Case pageOrigine"
        i = posLast + 1
        typeView = "Cumul volume"
        derSynoptOfType = DerviewUsed(typeView) 'position du dernier synoptique utilisé
        firstOfTypeView = firstTypeView(typeView)   ''position du premier synoptique utilisé
     
        '---     Appel de la procédure "chaqueTypeFlecheGauche(fso as object)
        chaqueTypeFlecheGauche a, typeView
     
     
        a.writeline "Case " & Left(firstOfTypeView, 3)
        a.writeline "                newView = " & Chr(34) & derSynoptOfType & Chr(34)
     
         '---     Appel de la procédure "chaqueTypeFlecheGauche(fso as object)
        a.writeline ""
        a.writeline
        a.Close
        Set a = Nothing
        Set fs = Nothing
    End Sub
    '  Procédure de sélection des vues dans la navigation des vues
    Sub chaqueTypeFlecheGauche(b As Object, typeVue)
        While Range("T_Vues_Synopt_WinCC[type]").Item(i) = typeVue
            If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(i) = "oui" Then
                    b.writeline "Case " & Left(Range("T_Vues_Synopt_WinCC[Vues]").Item(i), 3)
                    For k = i - 1 To 1 Step -1
                        If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(k) = "oui" Then
                            b.writeline "                newView = " & Chr(34) & Range("T_Vues_Synopt_WinCC[Vues]").Item(k) & Chr(34)
                            Exit For
                        End If
                    Next k
            End If
            i = i + 1
        Wend
    End Sub
    Function DerviewUsed(typeOfView)
    Dim j, nbLinec
    nbLine = Range("T_Vues_Synopt_WinCC[Vues]").Rows.Count
        For j = 1 To nbLine
            If Range("T_Vues_Synopt_WinCC[type]").Item(j) <> typeOfView And Range("T_Vues_Synopt_WinCC[Utilisé]").Item(j - 1) = "oui" Then
                j = j - 1
                posLast = j
                Exit For
            End If
        Next j
        DerviewUsed = Range("T_Vues_Synopt_WinCC[Vues]").Item(j)
    End Function
    Function firstTypeView(typeOfView)
    Dim j, nbLine
    nbLine = Range("T_Vues_Synopt_WinCC[Vues]").Rows.Count
        For j = 1 To nbLine
            If Range("T_Vues_Synopt_WinCC[type]").Item(j) = typeOfView And Range("T_Vues_Synopt_WinCC[Utilisé]").Item(j) = "oui" Then
                posFirst = j
                Exit For
            End If
        Next j
        firstTypeView = Range("T_Vues_Synopt_WinCC[Vues]").Item(j)
    End Function
     
     
    Sub headNavFleche(sPath)
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set a = fs.CreateTextFile(sPath, True)
        a.writeline "Dim newView     'Nouvelle page à ouvrir"
        a.writeline "Dim typeView    'e.g. Process, exploitation..."
        a.writeline ""
        a.writeline "If pageOrigine =100 Then pageOrigine = 101"
        a.writeline "If pageOrigine >= 101 And pageOrigine  <= 111 Then typeView = " & Chr(34) & "Process" & Chr(34)
        a.writeline ""
        a.writeline "If pageOrigine  >= 130 And pageOrigine < 140 Then typeView = " & Chr(34) & "Compteurs" & Chr(34)
        a.writeline ""
        a.writeline "If pageOrigine  >= 140 And pageOrigine < 150 Then typeView = " & Chr(34) & "Alarmes" & Chr(34)
        a.writeline ""
        a.writeline "If pageOrigine  >= 150 And pageOrigine < 160 Then typeView = " & Chr(34) & "Moteurs" & Chr(34)
        a.writeline ""
        a.writeline "If pageOrigine  >= 200 And pageOrigine < 300 Then typeView = " & Chr(34) & "Consignes" & Chr(34)
        a.writeline ""
        a.writeline "If pageOrigine  >= 300 And pageOrigine < 400 Then typeView = " & Chr(34) & "Courbes" & Chr(34)
        a.writeline ""
        a.writeline "Select Case typeView"
        a.writeline "    Case " & Chr(34) & "Process" & Chr(34)
        a.writeline "        Select Case pageOrigine"
        a.Close
        Set a = Nothing
        Set fs = Nothing
    End Sub

  2. #2
    Membre Expert Avatar de Zekraoui_Jakani
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    1 671
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2013
    Messages : 1 671
    Par défaut
    Essayez ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    chaqueTypeFlecheGauche (a), (typeView)

  3. #3
    Membre confirmé
    Homme Profil pro
    Automaticien
    Inscrit en
    Octobre 2019
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Octobre 2019
    Messages : 75
    Par défaut
    Bonjour,
    @Zekraoui_Jakani, j'ai une erreur "Argument non facultatif"...

  4. #4
    Membre confirmé
    Homme Profil pro
    Automaticien
    Inscrit en
    Octobre 2019
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Automaticien

    Informations forums :
    Inscription : Octobre 2019
    Messages : 75
    Par défaut
    Re tout le monde,
    j'ai un peu cherché midi à quatorze heure...

    J'ai enlevé " As Objet" dans la procédure appelé, et ça a fonctionné.
    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
    Dim posFirst, posLast
    Sub flecheGauche()
        Dim fs, i, derSynoptOfType, typeView, firstOfTypeView, path, chemin, fichier
        fichier = "scrpt_FlecheGauche.txt"
        chemin = "C:\expExcel\"
        path = chemin & fichier
     
        Set fs = CreateObject("Scripting.FileSystemObject")
        Set a = fs.opentextfile(path, 8, -2) ' 8 -> For Append, -2 -> TristateUseDefault
     
        typeView = "Synoptique"
        i = 1
        derSynoptOfType = DerviewUsed(typeView, i) 'position du dernier synoptique utilisé
        firstOfTypeView = firstTypeView(typeView, i)  ''position du premier synoptique utilisé
     
        chaqueTypeFlecheGauche a, typeView, i
    End Sub
    '  Procédure de sélection des vues dans la navigation des vues
    Sub chaqueTypeFlecheGauche(b, typeVue, k)
        While Range("T_Vues_Synopt_WinCC[type]").Item(k) = typeVue
            If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(k) = "oui" Then
                    b.writeline "               Case " & Left(Range("T_Vues_Synopt_WinCC[Vues]").Item(k), 3)
                    For j = k - 1 To 1 Step -1
                        If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(j) = "oui" Then
                            b.writeline "                newView = " & Chr(34) & Range("T_Vues_Synopt_WinCC[Vues]").Item(k) & Chr(34)
                            Exit For
                        End If
                    Next j
            End If
            j = j + 1
        Wend
    End Sub

  5. #5
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    par défaut, les arguments sont passés ByRef, référence directe à la variable.

    Ici, il faut utiliser un copie de la variable, et travailler en ByVal

    Par défaut, un paramètre est ByRef, pour passer en ByVal on doit lui dire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub chaqueTypeFlecheGauche(ByVal b, ByVal typeVue,ByVal k)
        While Range("T_Vues_Synopt_WinCC[type]").Item(k) = typeVue
            If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(k) = "oui" Then
                    b.writeline "               Case " & Left(Range("T_Vues_Synopt_WinCC[Vues]").Item(k), 3)
                    For j = k - 1 To 1 Step -1
                        If Range("T_Vues_Synopt_WinCC[Utilisé]").Item(j) = "oui" Then
                            b.writeline "                newView = " & Chr(34) & Range("T_Vues_Synopt_WinCC[Vues]").Item(k) & Chr(34)
                            Exit For
                        End If
                    Next j
            End If
            j = j + 1
        Wend
    End Sub

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut.

    Le problème vient du fait que ta variable a n'est pas déclarée, or ta procédure attend un objet: Sub chaqueTypeFlecheGauche(b As Object, typeVue)
    Si, dans la proc appelante, tu avais déclaré (Dim a As Object), tu n'aurais pas eu le problème. Les variables passées en arguments ByRef doivent être de même type que les arguments déclarés => il faut TOUJOURS déclarer ses variables...

    Deux billets pour bien comprendre:
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

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

Discussions similaires

  1. [RCP][débutant] Comment passer un objet d'une vue à une autre
    Par jycronier dans le forum Eclipse Java
    Réponses: 4
    Dernier message: 20/07/2006, 15h13
  2. Réponses: 4
    Dernier message: 20/04/2006, 11h07
  3. [JACOB] Comment passer un objet par référence à une méthode
    Par zlavock dans le forum Entrée/Sortie
    Réponses: 4
    Dernier message: 21/03/2005, 18h28
  4. [POO] Passer un objet HTML en argument.
    Par defacta dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 17/12/2004, 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