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

Excel Discussion :

code vba pour n° de semaine à partir d'une colonne de date


Sujet :

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 code vba pour n° de semaine à partir d'une colonne de date
    Bonjour à toutes et à tous

    J'utilise la fonction suivante pour avoir les numéros de semaine que j'applique sur une colonne qui comprend plus de 5000 dates

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Function NoSemaineISO(d As Date) As Integer
        NoSemaineISO = Format(d, "ww", vbMonday, vbFirstFourDays)
    End Function
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    Sub semISO()
        Dim lig As Long
        For lig = 2 To [A65536].End(xlUp).Row
                Cells(lig, 13) = NoSemaineISO(Cells(lig, 1))
        Next lig
    End Sub
    Cette macro fonctionne très bien mais le temps de traitement est trop important,
    j'ai donc pensé à utiliser les tableaux qui peuvent je pense améliorer la vitesse mais mes connaissances en vba sont limitées

    Merci infiniment pour votre aide

  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,
    Il existe une fonction native d'excel qui calcule le numéro de la semaine.
    Si tu souhaites par VBA, insérer une formule il est inutile de passer par une boucle. A lire ce billet Ecrire une formule dans Excel à l'aide d'une procédure VBA
    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
    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, sans certitudes, à tester
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    Option Explicit
     
    Private Declare Function QueryPerformanceCounter Lib "kernel32" (x As Currency) As Boolean
    Private Declare Function QueryPerformanceFrequency Lib "kernel32" (x As Currency) As Boolean
     
    Private Function NoSemaineISO(d As Date) As Integer
        NoSemaineISO = Format(d, "ww", vbMonday, vbFirstFourDays)
    End Function
     
    Sub semISO()
    Dim lig As Long
    Dim LastRow As Long
    Dim Dep As Currency, Fin As Currency, Freq As Currency
     
        QueryPerformanceCounter Dep
        Application.ScreenUpdating = False
        Application.Calculation = xlManual
        Application.EnableEvents = False
        LastRow = Feuil1.Range("A" & Rows.Count).End(xlUp).Row
        For lig = 2 To LastRow
            Feuil1.Cells(lig, 13) = NoSemaineISO(Feuil1.Cells(lig, 1))
        Next lig
     
        QueryPerformanceCounter Fin
        QueryPerformanceFrequency Freq
     
        Application.EnableEvents = True
        Application.Calculation = xlCalculationAutomatic
        Application.ScreenUpdating = True
     
        MsgBox Format(((Fin - Dep) / Freq), "0.000 s")
    End Sub

  4. #4
    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
    Bonjour et merci

    J'ai testé votre macro qui fonctionne bien, avec 7,6s pour appliquer cette fonction, c'est sensiblement le temps de ma boucle initiale !?

  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
    en appliquant la formule en vba
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .Offset(0, 13).FormulaR1C1 = "=INT(MOD(INT((R[2]C[-10]-2)/7)+0.6,52+5/28))+1"
    0,027s

    Un grand merci à vous deux

  6. #6
    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,
    Comme je l'ai écrit, pas besoin de boucle pour écrire une formule et c'est nettement plus rapide.
    Placement de la formule en colonne B
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     LastRow = Feuil1.Range("A" & Rows.Count).End(xlUp).Row
     With Feuil1
     .Range("B2:B" & LastRow).Formula = "=INT(MOD(INT((A2-2)/7)+0.6,52+5/28))+1"
     End With
    et avec la fonction native d'excel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     With Feuil1
     .Range("B2:B" & LastRow).Formula = "=WEEKNUM(A2,21)"
     End With
    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

  7. #7
    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 infiniment à vous deux

Discussions similaires

  1. Réponses: 11
    Dernier message: 29/06/2016, 15h31
  2. [XL-2010] Code aléatoire pour toutes les cellules vides d'une colonne
    Par GADENSEB dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 01/09/2014, 16h07
  3. [XL-2002] Code VBA pour colorier des cellules à partir de plusieurs critères
    Par NoodleDS dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 04/11/2013, 22h05
  4. Réponses: 8
    Dernier message: 15/04/2010, 10h24
  5. Réponses: 3
    Dernier message: 06/09/2005, 10h27

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