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 :

Numero de semaine [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut Numero de semaine
    Bonjour,

    Actuellement j'ai une macro qui enregistre mon fichier Excel sous le nom suivant : AuditSxx.xlsm
    Les deux "x" après AuditS représentent le n° de la semaine en cours.
    Actuellement nous sommes en semaine 11 donc ça sera AuditS11.xlsm
    Concernant les semaines 1 à 9, mes fichiers se nomment AuditS08.xlsm

    Je voudrais savoir quel code mettre pour activer le fichier de la semaine en cours.
    Actuellement je modifie chaque semaine ma macro dont le code est le suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Windows("AuditS11.xlsm").Activate
    et voici mon code pour enregistrer avec le n° de semaine en cours :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    nomfichier = ThisWorkbook.Name
     
    numSem = CInt(Right(Replace(nomfichier, ".xlsm", ""), 2))
     
    numSem = numSem - 1
     
    If numSem >= 10 Then
    nomfichier = "AuditS" & CStr(numSem) & ".xlsm"
    ElseIf numSem < 10 Then
    nomfichier = "AuditS0" & CStr(numSem) & ".xlsm"
    End If
    Merci

  2. #2
    Membre émérite Avatar de Nicolas JACQUIN
    Homme Profil pro
    .
    Inscrit en
    Avril 2014
    Messages
    556
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : .
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2014
    Messages : 556
    Par défaut
    Bonjour l'ami

    peut-être avec une chose comme celle-ci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nsemaine = DatePart("ww", Date, vbMonday, vbFirstFourDays)
    Windows("AuditS & "" & nsemaine.xlsm").Activate
    A essayer

  3. #3
    Membre Expert
    Inscrit en
    Septembre 2007
    Messages
    1 142
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 142
    Par défaut
    Bonjour à tous,

    Sans doute plutôt écrit ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nsemaine = DatePart("ww", Date, vbMonday, vbFirstFourDays)
    Windows("AuditS" & nsemaine & ".xlsm").Activate

  4. #4
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    bjr et merci pour ton aide mais ça ne marche pas

  5. #5
    Membre émérite Avatar de Nicolas JACQUIN
    Homme Profil pro
    .
    Inscrit en
    Avril 2014
    Messages
    556
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : .
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2014
    Messages : 556
    Par défaut
    Montre nous le code que tu utilise si possible

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nsemaine = DatePart("ww", Date, vbMonday, vbFirstFourDays)
    Workbooks("AuditS" & nsemaine & ".xlsm").Activate

  6. #6
    Expert éminent

    Profil pro
    Conseil, Formation, Développement - Indépendant
    Inscrit en
    Février 2010
    Messages
    8 568
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Conseil, Formation, Développement - Indépendant

    Informations forums :
    Inscription : Février 2010
    Messages : 8 568
    Par défaut
    Bonjour

    Imbriquer Nsemaine dans une fonction format afin d'avoir toujours 2 digits et enlever1 pour la semaine précédente
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    nsemaine = Format(DatePart("ww", Date, vbMonday, vbFirstFourDays) - 1, "00")
    Activate ne marche que si le fichier est ouvert...

  7. #7
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Salut.

    Je me demande quel est l'intérêt de travailler avec un classeur par semaine alors qu'une feuille XL2010 peut contenir 1048576 lignes de données...

    Ce serait tellement plus simple de tout regrouper dans un classeur.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  8. #8
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    Mais bien sûr sauf que la vie n'est pas si simple, tout comme les idees des grands chefs qui ont toujours raison.
    D'où un classeur par semaine.

  9. #9
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Ce n'est pas une question d'avoir raison ou d'être un grand chef.

    Si tu veux travailler efficacement avec un outil, il faut apprendre à le connaître et peut-être, petit à petit, infléchir le travail de celles et ceux qui t'imposent de mal travailler avec l'outil.

    Et perso, indépendamment de l'obligation d'un classeur par semaine pour la saisie, je les regrouperais en un seul classeur pour l'analyse en m'aidant de VBA pour consolider mes feuilles. Ca permettrait bien plus de souplesse, notamment dans l'analyse des données. Parce que j'imagine que si on encode des données dans 52 classeurs, c'est pour les analyser à un moment donné, et j'entrevois déjà trop bien l'usine à gaz que ça va donner, avec des discussions à 50 messages pour créer un château de cartes qui s'écroulera tôt ou tard.

    Tiens, je paries que tu vas t'amuser à copier ta macro dans chaque nouveau classeur que tu créeras chaque semaine. Ca va être rigolo côté maintenance.

    Cela dit, tu passes ton temps à le prendre de haut et à te casser le c** pour réaliser tes bricolages si tu en as envie, bien entendu
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  10. #10
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 222
    Par défaut
    je suis tout a fait d'accord avec toi mais quand on te dit c'est comme ça et c'est pas autrement tu te plis tant que tu es payé a la fin du mois.
    Ici l'analyse se fait par semaine et non pas par mois ni annee donc nous avons 52 copies du fichier original avec 52 noms différents S01, S02,......, S52

  11. #11
    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
    Un employeur a les collaborateurs qu'il mérite et vice-versa.

    Après, c'est une question de caractère personnel et d'auto-estime de chacun, mais également de la renommée que l'on fait de soi-même, notamment en vue d'un changement d'entreprise (le nouvel employeur aura tendance - et il aura raison - à juger de l'opportunité de recruter en fonction des performances montrées antérieurement ).
    Ceci est vrai quel que soit le domaine d'activité.

  12. #12
    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,
    Je ne peux que renchérir aux réponses de Pierre que je salue au passage.

    @graphikris
    Ici l'analyse se fait par semaine et non pas par mois ni annee donc nous avons 52 copies du fichier original avec 52 noms différents S01, S02,......, S52
    Si les données sont encodées dans une seule feuille, tu peux les synthétiser par jour, semaine, mois, trimestres et/ou années avec les tableaux croisés dynamiques ou à l'aide notamment de la fonction SOMMEPROD
    Avoir 52 feuilles pour une année est une aberration totale et en dehors des règles d'or de la manière dont doivent être encodées des données dans Excel
    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

  13. #13
    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
    Un s'impose, Philippe Tulliez. Je signe le mien.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 06/06/2006, 16h18
  2. Obtenir le numéro de semaine en cours
    Par beauseigne dans le forum Access
    Réponses: 2
    Dernier message: 21/04/2006, 18h32
  3. Pb avec numero de semaine
    Par zxr69 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 13/01/2006, 13h02
  4. [Dates] Numero de semaine ISO et dates ??
    Par MadCat34 dans le forum Langage
    Réponses: 9
    Dernier message: 19/11/2005, 00h00
  5. Réponses: 10
    Dernier message: 20/09/2005, 15h32

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