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 :

[Excel] Log des utilisateurs


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Inscrit en
    Décembre 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 143
    Points : 38
    Points
    38
    Par défaut [Excel] Log des utilisateurs
    Bonjour,

    J'aimerais connaître les personnes qui ouvrent mon fichier Excel et stocker le tout dans une autre feuille cachée de mon classeur.
    J'ai réussi à faire une fonction qui stocke le nom et la date, dans un fichier texte à part.
    Mais je n'arrive pas à l'adapter à mes besoins.

    Voici le bout de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Private Sub Workbook_Open()
     
    Open ThisWorkbook.Path & "\usage.log" For Append As #1
    Print #1, Application.UserName, Now
    Close #1
    End Sub
    Par la suite, je voudrais faire la même chose pour ceux qui modifie le fichier.

  2. #2
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Citation Envoyé par wanou44
    Mais je n'arrive pas à l'adapter à mes besoins.
    Quel est-il ? Noter l'identité de celui qui modifie le fichier ?

  3. #3
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Citation Envoyé par wanou44
    ...
    Par la suite, je voudrais faire la même chose pour ceux qui modifie le fichier.
    utilise l'événement Workbook_BeforeSave ..

  4. #4
    Nouveau membre du Club
    Inscrit en
    Décembre 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 143
    Points : 38
    Points
    38
    Par défaut
    Citation Envoyé par ouskel'n'or
    Quel est-il ? Noter l'identité de celui qui modifie le fichier ?
    Non, mon besoin est de stocker la liste des personnes ouvrant ce fichier dans une feuille cachée du classeur et non dans un fichier texte à part.

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Donc tu as deux listes dans ta feuille masquée, la première des visiteurs, la seconde de ceux qui modifient les données.
    la proposition de bbil (Workbook_BeforeSave) place dans ta deuxième liste le nom de tous ceux qui enregistrent le fichier, modifié ou non.
    Si tu ne veux, dans cette deuxième liste, n'avoir que ceux qui ont modifié le fichier, tu as plusieurs solutions plus ou moins fiables, la plus fiable étant la plus lourde car elle passerait par la création d'une copie de ton fichier à l'ouverture, puis une comparaison de cette copie avec ton fichier à l'enregistrement, puis en une destruction de la copie. Je ne suis pas sûr qu'on puisse faire ça fichier ouvert (forcément ouvert puisque contenant les macros)
    La plus simple passerait par la comparaison de la taille du fichier entre l'ouverture et l'enregistrement.
    Précise tes "exigences"

  6. #6
    Nouveau membre du Club
    Inscrit en
    Décembre 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 143
    Points : 38
    Points
    38
    Par défaut
    Citation Envoyé par ouskel'n'or
    Donc tu as deux listes dans ta feuille masquée, la première des visiteurs, la seconde de ceux qui modifient les données.
    la proposition de bbil (Workbook_BeforeSave) place dans ta deuxième liste le nom de tous ceux qui enregistrent le fichier, modifié ou non.
    Si tu ne veux, dans cette deuxième liste, n'avoir que ceux qui ont modifié le fichier, tu as plusieurs solutions plus ou moins fiables, la plus fiable étant la plus lourde car elle passerait par la création d'une copie de ton fichier à l'ouverture, puis une comparaison de cette copie avec ton fichier à l'enregistrement, puis en une destruction de la copie. Je ne suis pas sûr qu'on puisse faire ça fichier ouvert (forcément ouvert puisque contenant les macros)
    La plus simple passerait par la comparaison de la taille du fichier entre l'ouverture et l'enregistrement.
    Précise tes "exigences"
    La solution de bbil me convient parfaitement. Je l'ai mise en test et ça fonctionne.

    Par contre, je n'arrive toujours pas à enregistrer ces 2 listes dans une feuille cachée de mon classeur. Pour l'instant, j'ai un fichier usage.log et usage2.log.
    Pouvez-vous m'aider ?

  7. #7
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    tiens pour le principe pour l'écriture dans une feuille:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Dim iDerLigne As Integer
    Set wsLog = Sheets("MaFeuilleLog")
    iDerLigne = wsLog.Range("A65535").End(xlUp).Row + 1
    wsLog.Cells(iDerLigne, 1) = Application.UserName
    wsLog.Cells(iDerLigne, 2) = Now
    Set wsLog = Nothing

  8. #8
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Tu dois "dé-masquer" ta feuille avant de copier les données dedans avant de la masquer de nouveau. Et pour ne pas voir les mouvements de feuilles, tu mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.screenupdating = False 'avant d'afficher ta feuille
    'et
    Application.screenupdating = True 'une fois ta feuille de nouveau masquée
    A+

  9. #9
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    Citation Envoyé par ouskel'n'or
    Tu dois "dé-masquer" ta feuille avant de copier les données dedans avant de la masquer de nouveau. Et pour ne pas voir les mouvements de feuilles, tu mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Application.screenupdating = False 'avant d'afficher ta feuille
    'et
    Application.screenupdating = True 'une fois ta feuille de nouveau masquée
    A+
    ?? non je pense pas ..?

    [Edit] non je suis sur

  10. #10
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    Citation Envoyé par bbil"
    ?? non je pense pas ..?

    [Edit] non je suis sur
    C'est bien !

  11. #11
    Nouveau membre du Club
    Inscrit en
    Décembre 2005
    Messages
    143
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 143
    Points : 38
    Points
    38
    Par défaut
    Merci ça marche nickel !!!

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

Discussions similaires

  1. Une table log Formulaire modification des utilisateurs
    Par pasb71 dans le forum VBA Access
    Réponses: 5
    Dernier message: 22/07/2011, 06h30
  2. [SP-2007] Accéder aux logs des utilisateurs
    Par rohstev dans le forum Configuration
    Réponses: 4
    Dernier message: 14/04/2011, 00h33
  3. Réponses: 6
    Dernier message: 02/02/2009, 10h52
  4. Réponses: 5
    Dernier message: 26/11/2008, 11h03
  5. Win Server 2003 - Logs des connexions utilisateurs ?
    Par nerick dans le forum Windows Serveur
    Réponses: 0
    Dernier message: 14/05/2008, 13h42

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