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 :

comportement différent de Show entre Sub et Function [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Inscrit en
    Août 2009
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 13
    Par défaut comportement différent de Show entre Sub et Function
    bonjour,

    quand j'appelle cible.Show à partir d'une exécution de Sub CompteCommentaires, j'obtiens bien la cellule au centre de la fenêtre Excel (en général, cachée derrière la MsgBox )

    Quand je place la Function CountCommentParCol () dans la feuille Excel, cellule B2007
    =CountCommentParCol(B$5:B1950)

    la macro fonctionne, mais la feuille reste scotchée à
    proximité de la cellule B2007

    POurquoi ?

    ET le r.Show dans la fonction ne fait absolument rien !

    nb: j'utilise une fonction pour pouvoir faire des copies de formules dans toutes les colonnes qui m'intéressent en usant des adresses relatives ; je n'ai pas trouvé comment faire en macro Sub


    Merci de me dire ce que j'ai oublié dans ce code

    A+

    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
    Function CountCommentParCol(Zone As Range) As String
     
        Dim r As Range
        Dim lig, col As Integer
        Dim MsgZone As String
        Dim NbComments As Long
     
        NbComments = 0
     
        Set r = Zone
        r.Show
     
        MsgZone = "Explore la colonne " & r.Cells().Address
        MsgBox MsgZone
     
        For col = 1 To r.Columns.Count
            For lig = 1 To r.Rows.Count
                CompteCommentaires Range(r.Cells(lig, col).Address()), NbComments
            Next lig
        Next col
     
        CountCommentParCol = NbComments
    End Function
     
    Private Sub CompteCommentaires(cible As Range, NbComments As Long)
     
        If cible.Comment Is Nothing Then
            'MsgBox ("Aucun commentaire dans la cellule cible " & cible.Row & "," & cible.Column)
        Else
            NbComments = NbComments + 1
            cible.Show
     
            ' Affiche le message.
            MsgBox ("Cellule cible " & cible.Address() & " : [" & cible.Comment.Text & "]")
        End If
     
    End Sub

  2. #2
    Inactif  
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 054
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 054
    Par défaut
    Bonjour,
    Une fonction personnalisée ne peut interagir sur aucun objet.
    A+

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

Discussions similaires

  1. Variable de retour problèmatique entre Sub et Function
    Par Tchupacabra dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 27/05/2009, 10h44
  2. Réponses: 12
    Dernier message: 26/10/2007, 17h27
  3. Réponses: 3
    Dernier message: 04/06/2007, 14h05
  4. [AJAX] Comportement différent entre IE et FF2
    Par pacopau dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 14/02/2007, 20h18
  5. Comportement différent entre un bouton et une image
    Par MicheMTP13 dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 07/11/2005, 09h47

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