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 :

comment transformer les codes des jours comme 'J20150703' to 2015/07/03


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Drôme (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2014
    Messages : 10
    Par défaut comment transformer les codes des jours comme 'J20150703' to 2015/07/03
    Bonjour,

    Comment transformer les codes des jours comme 'J20150703' to 2015/07/03

    exemple
    J20150703 to 2015/07/03
    J20150610 to 2015/06/10
    J20150520 to 2015/05/20
    J20150409 to 2015/04/09
    J20150320 to 2015/03/20
    J20150311 to 2015/03/11

    Merci

  2. #2
    Inactif  

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2012
    Messages
    4 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4 903
    Billets dans le blog
    36
    Par défaut
    Bonjour,

    Fonction Mid() dans l'aide de VBA
    & = opérateur de concaténation dans l'aide de VBA

    pour l'année

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub TrouveLAnnée()
       Dim CetteDate As String
       Dim UneAnnée As Integer
       Dim LAnnée As String
       CetteDate = "J20150703"
       LAnnée = Mid(CetteDate, 2, 4)
       UneAnnée = CInt(LAnnée)
    End Sub
    Au pire tu cliques sur mid dans l'éditeur et tu appuies sur

  3. #3
    Expert confirmé
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ex Observeur CGG / Analyste prog.

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132
    Par défaut
    Salut, sous forme de fonction personnalisée
    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
    Option Explicit
     
    Function ConvDate(sDate As String) As String
    Dim sAn As String, sMois As String, sJour As String
        sAn = Mid$(sDate, 2, 4)
        sMois = Mid$(sDate, 6, 2)
        sJour = Mid$(sDate, 8, 2)
        ConvDate = sAn & "/" & sMois & "/" & sJour
    End Function
     
    Sub Tst()
    Dim sStr As String
        sStr = "J20150520"
        MsgBox ConvDate(sStr)
    End Sub
    Images attachées Images attachées  

  4. #4
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    chaine = "J20150703"
    MsgBox Format(CDate(Format(Mid(chaine, 2), "####/##/##")), "yyyy/mm/dd")
    notons que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CDate(Format(Mid(chaine, 2), "####/##/##"))
    retournerait quant à lui 03/07/2015

    mais que (mais moins orthodoxe car on passe à côté d'une contrainte de date)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Format(Mid(chaine, 2), "####/##/##")
    retournerait aussi "2015/07/03"
    ainsi d'ailleurs que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Format(Mid(chaine, 2), "@@@@/@@/@@")
    EDIT : que décider alors ?
    Ma réponse : c'est selon.
    - selon que la chaîne chaine a fait l'objet d'une vérification de contrainte de validité de date au moment même de sa construction et dans ce cas la solution 3 ou 4 convient et suffit
    ou
    - selon que la chaîne a été construite sans cette vérification (ou que, extraite d'ailleurs, on n'est pas certain de ce que cette vérification a été faite en amont) et la solution 1 est alors à privilégier car elle donne l'occasion d'alerter éventuellement (avant d'autres dégâts possibles).

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    d=Cdate(format(Replace ("J20150703","J","")"0000-00-00"))Edite: effectivement
    d=Cdate(format(Replace ("J20150703","J",""),"0000-00-00"))
    Dernière modification par Invité ; 26/07/2016 à 10h47.

  6. #6
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour durupt
    n'oublie pas la virgule nécessaire après la 4ème parenthèse.
    Egalement, mais ainsi, on obtient non aaaa/mm/jj, mais jj/mm/aaaa

Discussions similaires

  1. Réponses: 8
    Dernier message: 06/07/2016, 07h59
  2. Réponses: 6
    Dernier message: 28/06/2014, 09h30
  3. Réponses: 1
    Dernier message: 16/05/2013, 16h31
  4. Comment transformer les tables dans un fichier txt vers une BD comme Mysql
    Par badrdine.in dans le forum Développement de jobs
    Réponses: 5
    Dernier message: 20/03/2009, 12h58
  5. Comment programmer les codes couleurs au dela des 16 courants
    Par B-Pascal dans le forum SAP Crystal Reports
    Réponses: 5
    Dernier message: 01/02/2008, 09h31

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