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

Access Discussion :

[DATES] Règles pour le numéro de la semaine


Sujet :

Access

  1. #1
    Membre habitué Avatar de kirgan
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    127
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 127
    Points : 136
    Points
    136
    Par défaut [DATES] Règles pour le numéro de la semaine
    hello,

    j'ai une question assez globale, mais vu que je suis sur Access, je vous la pose ici.

    Je n'ai en effet pas trouvé la réponse dans les posts ni les FAQ.

    Pour une appli de gestion, j'ai besoin de connaître, pour un mois donné, les semaines qui le composent. Je n'ai aucun problème à extraire un numéro de semaine d'une date, etc. Mon problème est uniquement au niveau "gestion". Existe-t-il une règle qui dit que, si le premier jour du mois est par exemple un jeudi, cette semaine-là sera sur le mois précédent? Ou bien dois-je définir ces règles en interne?

    En gros, si une semaine est à cheval sur 2 mois, où la mettre? Et encore mieux, Access aurait-il par hasard une fonction toute faite...?

    Si vous avez déjà rencontré ce "problème", vos avis m'intéressent!

    Merci d'avance

    edit:
    passer via VbFirstWeekOfYear, et calculer, vous semble une bonne idée? Ou bien tiré par les cheveux...

  2. #2
    Invité
    Invité(e)
    Par défaut Salut,
    Normalement,

    La semaine commençant toujours par un Lundi
    le numéro de la semaine est imputable sur le mois contenant ce Lundi

    Il suffit donc de calculer la date du lundi par rapport au premier jour du mois, et le tour est joué !

    A+

  3. #3
    Membre habitué Avatar de kirgan
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    127
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 127
    Points : 136
    Points
    136
    Par défaut
    Citation Envoyé par BrunoM45
    La semaine commençant toujours par un Lundi
    C'est ce que je pensais, mais apparemment pas pour Access... La semaine commence le dimanche, ce qui m'emballe moyennement.

    En gros, pour Access, et en utilisant la méthode de Maxence LastDayOfMonth(), ainsi qu'une méthode FirstDayOfMonth(), si l'utilisateur entre n'importe quelle date du mois qui l'intéresse, je récupère les premier et dernier jours du mois, puis de là j'extrais les semaines de début et de fin. Ca marche moyennement (si un mois commence le samedi, je vais avoir la semaine d'avant, mais ca, ca passe encore). Par contre, si le mois finit le dimanche (comme avril 2006), il m'inclut la semaine 18 dans avril...

    Ca m'a toujours énervé les dates Et en plus, je sens que ca va encore plus me faire tourner en bourrique, car certains users n'ont pas le même profil régional...




    Edit:
    En fait, c'est encore plus bizarre que je ne le pensais... en 2011 (ben ouais, j'ai testé), le 01/01 est un samedi. Et Access me dit, logiquement, que le 02/01 est la.... DEUXIEME semaine. Or, franchement, j'en doute...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function GetTest() As String
        GetTest = DatePart("ww", GetDateCurrent())
    End Function
    GetDateCurrent() me renvoie une date sélectionnée dans un calendar visuel.

  4. #4
    Invité
    Invité(e)
    Par défaut Tiens je te donne une aspirine...
    Bout de code de ce cher Walter Stucki
    http://mypage.bluewin.ch/w.stucki/Ca...ates.htm#NoSem

    Tu appelles la fonction comme tu veux avec la valeur de ta date
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Function NoSemaine(Optional UneDate As Date = 0) As Integer
    ' Objectif: UneDate est la date dont on veut calculer le numéro de semaine européen
    ' En Europe, la 1ère semaine d'une nouvelle année est la semaine contenant le premier lundi
    ' Aux USA, la 1ère semaine est celle du 1er janvier.
    ' Exemple: Format("01/10/2000","ww", vbMonday, vbFirstFullWeek) donne 40
    ' Exemple: DatePart("ww","01/01/2002",vbMonday,vbFirstFullWeek) donne 53 (dernière semaine de l'an 2001)
    ' Ce résultat de 53 est obtenu quand le 1er janvier est un mardi ou quand le 1er janvier est un mercredi et que
    ' l'année précédente est bissextile.
    If UneDate = 0 Then
       UneDate = Date
    End If
    NoSemaine = DatePart("ww", UneDate, vbMonday, vbFirstFullWeek)
    End Function
    J'ai testé le 02/01/2011 appartient à la 52ème semaine (Exacte)

    Voilà


  5. #5
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Salut,
    Citation Envoyé par BrunoM45
    J'ai testé le 02/01/2011 appartient à la 52ème semaine (Exacte)

    Voilà

    Ce bug vient qu'access utilise le calendrier anglais (il ne font pas comme nous). La seul solution est de ce créer un calendrier.

  6. #6
    Invité
    Invité(e)
    Par défaut Je ne comprends pas...
    Ce bug vient qu'access utilise le calendrier anglais (il ne font pas comme nous)
    Quel BUG !? La fonction que j'ai donné marche parfaitement !

    La seul solution est de ce créer un calendrier
    Ah, quand même

    A+

  7. #7
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Sorry

    Je n'ai lu qu'entre les lignes. All right ceci fonctionne

  8. #8
    Membre habitué Avatar de kirgan
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    127
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2006
    Messages : 127
    Points : 136
    Points
    136
    Par défaut
    Merci, ca va mettre un peu de joie dans mon vendredi pluvieux (il m'en faut peu, je sais)

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

Discussions similaires

  1. Date en fonction du numéro de la semaine
    Par Vorehan dans le forum Général VBA
    Réponses: 1
    Dernier message: 08/07/2013, 22h59
  2. Réponses: 1
    Dernier message: 04/05/2010, 16h58
  3. [VB.NET] Obtenir le numéro de la semaine d'une date
    Par alain&&thomas dans le forum Windows Forms
    Réponses: 9
    Dernier message: 07/09/2009, 17h54
  4. le numéro d'une semaine à partir d'une date
    Par crazydede8 dans le forum C++
    Réponses: 5
    Dernier message: 22/09/2006, 20h27
  5. Réponses: 14
    Dernier message: 01/06/2006, 17h32

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