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 :

Gérer un N° de file à partir de plusieurs utilisateurs [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    817
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 817
    Par défaut Gérer un N° de file à partir de plusieurs utilisateurs
    Bonjour,

    J'ai un classeur qui sera utilisé en lecture seule par plusieurs utilisateurs.
    à partir de ce classeur, j'ouvre un classeur contenant un numéro dans une cellule, j'incrémente j'enregistre et je ferme.
    même si j'ai peu de chance d'avoir un accès simultané sur ce fichier d'index, il faut que je gère cette éventualité.
    de plus les réseaux étant ce qu'ils sont, on a souvent des problèmes soit de performance soit d'accès au motif que le fichier est en cours d'utilisation par un autre utilisateur (cas des prévisualisation dans l'explorer Windows par exemple) même si personne n'est dans le classeur.

    J'ai un peu peur de me lancer dans l'ODBC décrit ici par
    http://silkyroad.developpez.com/VBA/ClasseursFermes/

    J'ai pensé remplacer mon N° de file par la date interne d'Excel, mais ça va me faire un drôle de N° exemple là maintenant() me renvoie 43041,57524.
    Là j'ai éventuellement un risque de doublon mais très faible et pas vital dans mon cas!

    Auriez vous une autre idée pour réaliser cette fonction.
    Merci

  2. #2
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut
    Bonjour !

    Citation Envoyé par Denis_67 Voir le message
    j'ouvre un classeur contenant cette un numéro dans une cellule
    En français ? Rien compris !

    Pour rappel multi-utilisateurs sous Excel & VBA ne font pas bon ménage, c'est plutôt bancale …

    ___________________________________________________________________________________________________________
    Je suis Paris, New-York, Mogadicio, Barcelone, London, Manchester, Egypte, Stockholm, Istanbul, Berlin, Nice, Bruxelles, Charlie, …

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonsoir,
    Tu peux personnaliser le numéro de fichier par des informations ce trouvant explicitement sur la machine!

    Adresse Mac, numéro de série du disk dur, la personne logué etc...
    Environ("username") & "_" & date

  4. #4
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    817
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 817
    Par défaut
    Merci pour ta remarque Marc,
    J'ai corrigé la coquille !

    Cependant je vais avoir plusieurs documents emis le même jour la même heure la même minute (voire la même seconde)
    je veux bien les différencier, donc je vais récupérer le n° entier avec la partie décimale.
    Je vais juste * par 100 000 pour avoir un nombre entier !
    je peux potentiellement avoir des doublons si deux utilisateurs valident au même instant.

    Denis

  5. #5
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    817
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 817
    Par défaut
    bon en ecrivant je me rends compte que c'est un peu C.... d'afficher un N° qui est une date, dns ce cas je peux afficher la date aussi comme identifiant unique.

    Cependant pour comprendre
    dans mon VBA j'ai capturé la date now() dans une variante, mais si je la multiplie par 100 000 evidemmentca me raclacule une date dans 100 000 ans
    Comment on récupère la date en format interne et on découpe la partie entière et la partie décimales ?
    Denis

  6. #6
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut


    Une date étant forcément une valeur numérique entière sous Excel
    • soit utiliser la fonction VBA Fix par exemple pour tronquer, facilement trouvable juste en ouvrant l'aide VBA interne;
    • soit juste avec un peu de jugeote utiliser une fonction Excel renvoyant une date donc sans heure …

  7. #7
    Membre éclairé
    Inscrit en
    Août 2009
    Messages
    817
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 817
    Par défaut
    Merci

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 19/12/2005, 19h08
  2. Crée image à partir de plusieurs Timage
    Par spikto dans le forum Composants VCL
    Réponses: 2
    Dernier message: 09/08/2005, 14h38
  3. [ImageMagick] Générer une image à partir de plusieurs images ?
    Par fichtre! dans le forum Bibliothèques et frameworks
    Réponses: 8
    Dernier message: 16/02/2005, 15h32
  4. [SUM] récuperer une quantite a partir de plusieurs table
    Par Snowballz dans le forum PostgreSQL
    Réponses: 9
    Dernier message: 14/09/2004, 18h48
  5. [Servlet][IO]Ecrire un File à partir d'un InputStream
    Par ravioli dans le forum Servlets/JSP
    Réponses: 4
    Dernier message: 04/02/2004, 10h15

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