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 :

Récupérer le numéro du mois à partir de son nom


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 126
    Points : 53
    Points
    53
    Par défaut Récupérer le numéro du mois à partir de son nom
    Bonjour,

    J'aimerai savoir s'il existe une fonction (mais aprés avoir bien cherché, je ne crois pas) qui pourrai donner le numéro du mois en ayant son nom français.
    Par exemple, FonctionMois("décembre") =12, où fonctionMois est le nom de la fonction.

    Je sais que l'inverse existe (MonthName), mais je ne peux pas m'en servir pour ce que je veux faire.

    Merci pour votre aide

    Ceuce

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour Ceuce,

    A partir d'une formule sur Excel :

    Ou exemple en VBA :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    nmois = Month("01 " & Cells(1, 1))
    Dernière modification par Invité ; 13/09/2007 à 12h30. Motif: j'ai enlevé la variable contenant l'année puisqu'on en a pas besoin

  3. #3
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 535
    Points
    5 535
    Par défaut
    Bonjour,

    Exemple, ntre autres possibilités :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Command1_Click()
     monmois = "décembre"
     MsgBox Month("01 " & monmois & " 2000")
     monmois = "mars"
     MsgBox Month("01 " & monmois & " 2000")
    End Sub
    Bonne continuation...

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 126
    Points : 53
    Points
    53
    Par défaut
    Bonjour à tous les 2 et merci de m'avoir répondu.

    Je pense que je me suis mal exprimée. Je cherche par exemple le moyen de trouver 12 avec une fonction vba en ayant seulement le string "décembre" comme argument.

    Suis-je plus clair?

  5. #5
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 535
    Points
    5 535
    Par défaut
    Explique, expose... CLAIREMENT ... et COMPLETEMENT
    Ne "tourne donc pas autour du vrai pot"
    Et tu auras la réponse précise..

  6. #6
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Rien ne t'empêche de la faire ta fonction.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Public Fucntion MyMois(monMois as string) as string
    Select Case monMois
    Case "janvier"
    MyMois = "01"
    Case "février"
    MyMois = "02"
    .....
     
    End Function
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  7. #7
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Ou peut-être en plus court

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function ChiffreMois(strMois As String) As Long
        ChiffreMois = Month(CDate("01 " & strMois & " 2007"))
    End Function
    Ex : ChiffreMois("février") te donnera 2

    Pense à mettre une gestion d'erreur, si le mois est mal saisi.

    Starec

  8. #8
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 535
    Points
    5 535
    Par défaut
    J'ai signalé une manière plus haut, en précisant qu'il y en avait beaucoup !

    En voilà une 2ème (parmi d'autres encore) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub Command1_Click()
     MsgBox Format("janvier" & " 01 2001", "mm")
     MsgBox Format("août" & " 01 2001", "mm")
    End Sub

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 126
    Points : 53
    Points
    53
    Par défaut
    merci à tous,

    j'avais opté pour la solution proposé par Heureux-oli en attendant de trouver une solution plus simple (enfin qui prend moins de place), mais je vais regarder vos propositions.

    ceuce

  10. #10
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 535
    Points
    5 535
    Par défaut
    Pendant que tu en es à l'examen :

    Vois donc également celle-ci (qui colle parfaitement aux particularismes de VB, mais est certes un peu plus difficile à comprendre) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub Command1_Click()
     monmois = "février"
     MsgBox Month(DateValue(monmois & ", 0"))
    End Sub
    Bonne continuation...

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    126
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 126
    Points : 53
    Points
    53
    Par défaut
    Et bien finalement j'opte pour ta proposition ucfo, c'est la plus simple à mes yeux! Encore merci

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

Discussions similaires

  1. Récupérer le numéro du mois à partir de son nom
    Par sabrine1311 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 07/05/2014, 09h46
  2. Récupérer un widget à partir de son nom
    Par kenshi240683 dans le forum GTK+ avec C & C++
    Réponses: 2
    Dernier message: 27/05/2008, 14h18
  3. Réponses: 9
    Dernier message: 26/09/2007, 16h18
  4. Récupérer une variable à partir de son nom ...
    Par CynO dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 13/10/2005, 16h59
  5. Réponses: 3
    Dernier message: 24/09/2004, 21h21

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