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 :

Numérotation automatique dans formulaire


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
    administrateur
    Inscrit en
    Mai 2015
    Messages
    74
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : administrateur

    Informations forums :
    Inscription : Mai 2015
    Messages : 74
    Par défaut Numérotation automatique dans formulaire
    Bonjour à tous,

    Je dispose d'un formulaire de saisie qui affiche automatiquement à l'ouverture dans un textbox un numéro d'ordre qui suit le dernier numéro saisie.
    Le format de ce numéro est
    Format(Date, "yymm") soit 1905 suivi du chiffre 1,2,3 etc
    ce qui donne
    19051
    19052
    19053
    19054
    etc
    Ce que je souhaite avoir, c'est
    1905001
    1905002
    1905003
    1905004
    etc

    Voilà le code que j'utilise du formulaire "Ben" correspondant à ce numéro
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     
     Set f = Workbooks("GB.xlsx").Sheets("Bens")
        Ligne = f.Range("A65536").End(xlUp).Row
        If Ligne = 1 Then
        Ben.N_I = Format(Date, "yymm") & "1"
        Else
        Ben.N_I = Format(Date, "yymm") & Right(f.Cells(Ligne, 1), Len(f.Cells(Ligne, 1)) - 4) + 1
        End If
    Comment modifier ce code pour obtenir le résultat souhaité?
    Merci infiniment pour vos réponses

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 176
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    J'ai écrit une fonction personnalisée qui renvoie le prochain numéro.
    Voir ce billet titré Incrémenter un numéro de facture, devis, à l’aide d’une fonction personnalisée
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre confirmé
    Homme Profil pro
    administrateur
    Inscrit en
    Mai 2015
    Messages
    74
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : administrateur

    Informations forums :
    Inscription : Mai 2015
    Messages : 74
    Par défaut
    Bonsoir
    Merci pour votre réponse, j'ai regardé votre fonction mais c'est peut être un peu compliqué pour moi...
    pour reprendre tout ça
    Alors j'ai modifié mon code comme ceci pour avancer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Set f = Workbooks("GB.xlsx").Sheets("Bens")
        Ligne = f.Range("A65536").End(xlUp).Row
        n = Right(f.Cells(Ligne, 1).Value, 3)
        Num = Format(n + 1, "000")
    Ben.N_I = Format(Date, "yymm") & Num
    c'est un peu tiré par les cheveux car je suis obligé dans ce cas de mettre une valeur de champ comme par exemple TOTO_000
    mais ça fonctionne
    Peut être auriez vous la solution quelque soit la valeur du champ?

  4. #4
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 176
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Merci pour votre réponse, j'ai regardé votre fonction mais c'est peut être un peu compliqué pour moi...
    pour reprendre tout ça
    Je ne vois pas où est la difficulté, c'est une fonction "clé sur porte" qu'il suffit de copier dans un module standard et ensuite l'invoquer
    En VBA
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Variable = Counter(AncienNuméro)
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A2").Value = Counter(AncienNuméro)
    et en Excel si l'ancien numéro se trouve en cellule B2 de la feuille nommée Parameter (Cellule que l'on peut nommer bien entendu)
    et pour l'avoir formaté 1905-005 (Exemple pour le n° 5 pour le 16/05/2019)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =TEXTE(AUJOURDHUI();"aamm") & "-" & TEXTE(Counter(Parameter!B2);"000")
    Mais cette fonction peut aussi recommencer la numérotation par période (Année, Trimestre, Mois, Hebdomadaire et Jour)
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #5
    Membre confirmé
    Homme Profil pro
    administrateur
    Inscrit en
    Mai 2015
    Messages
    74
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : administrateur

    Informations forums :
    Inscription : Mai 2015
    Messages : 74
    Par défaut
    Merci Philippe pour vos réponses
    je vais appliquer votre fonction et je reviens vers vous si j'ai des difficultés
    Bonne soirée

Discussions similaires

  1. [XL-2010] Numérotation automatique dans un formulaire.
    Par DRARVUO99 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/09/2016, 15h43
  2. écriture automatique dans formulaire
    Par Hurin dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 25/07/2007, 14h57
  3. Créer des champs en automatique dans formulaire
    Par Daniel MOREAU dans le forum VBA Access
    Réponses: 5
    Dernier message: 28/06/2007, 18h14
  4. Date automatique dans formulaire
    Par ildan dans le forum IHM
    Réponses: 3
    Dernier message: 31/05/2007, 16h22
  5. [Cookies] insertion de données automatique dans formulaire
    Par chouchouboy dans le forum Langage
    Réponses: 8
    Dernier message: 09/06/2006, 11h50

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