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 :

Coment filtrer sur des dates dans Excel avec une macro [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 142
    Points : 84
    Points
    84
    Par défaut Coment filtrer sur des dates dans Excel avec une macro
    Bonjour,

    Je rencontre un petit problème concernant le filtrage de dates . Lorsque j'execute le filtrage manuellement sur des dates, le résultat correspond aux critères. Par contre lorsque j'effectue cette commande via une macro, rien ne se passe (en tout cas rien n'est visible) car je ne vois que la 1ère ligne avec le nom des colonnes .
    Pourriez-vous m'apporter votre aide sur ce sujet ?

    merci
    salutations

    MichaSarah

    Excel 2003 & Windows XP

  2. #2
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 642
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 642
    Points : 34 349
    Points
    34 349
    Par défaut
    salut,
    te serait-il possible de nous fournir le code VBA que tu utilises stp, au'on puisse avoir une idee des choses a modifier

  3. #3
    Expert éminent
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    3 906
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 3 906
    Points : 8 539
    Points
    8 539
    Par défaut
    Salut
    C'est lié a un problème de format de date il me semble, cette question a été posé il y a quelque jours/semaines, pour ta défense (toujours faire une recherche avant de poster) je n'arrive pas a la retrouver non plus...

    essai quelque chose comme ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Criteria1:=">" & Format(Range("A1"), "mm/dd/yyyy")
    a++
    Qwaz

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 142
    Points : 84
    Points
    84
    Par défaut
    Bonjour,
    Je vous transmets ci dessous le code que j'utilise. En // j'essaye avec la proposition de Qwazerty . Avant de poster j'avais cherché dans les forum mais la seule réponse que j'avais trouvé traitait du format de la date. J'avais testé mais sans résultat.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    Selection.AutoFilter Field:=73, Criteria1:=">=01/01/2010", Operator:= _
            xlAnd, Criteria2:="<=31/12/2010"
    merci
    salutations
    MichaSarah

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 142
    Points : 84
    Points
    84
    Par défaut
    Bonjour,

    La solution de Qwazerty fonctionne mais pour afficher le résultat à l'écran, il faut qu'après avoir lancé la macro je retourne sur la sélection du filtre , Je dois faire ensuite personnaliser puis OK et là le résultat s'affiche à l'écran.
    Le code que j'ai mis est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Selection.AutoFilter Field:=73, Criteria1:=">=" & Format("01/01/2010", "dd/mm/yyyy"), Operator:= _
            xlAnd, Criteria2:="<=" & Format("31/12/2010", "dd/mm/yyyy")
    Y a t-il moyen d'éviter les dernières actions après lancement de la macro ?

    Merci
    Salutations

    MichaSarah

  6. #6
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 699
    Points
    6 699
    Par défaut
    Bonjour,

    il s'agit bien d'un problème de format, mais plus précisément d'interprétation de date... Ca devient plus simple si on a compris le fonctionnement de la chose :

    Comprendre et gérer les dates sous Excel et en VBA

    Ton résultat doit provenir du fait que tu utilises un format cellule différent de celui adopté dans ton filtre.
    Testes avec l'enregistreur de macros avec différents formats cellule et différents formats de saisie dans le filtre feuille et analyse le résultat du code obtenu qui travaille en String.

    Sinon, je te propose le code suivant qui n'est pas sensible au format date de tes cellules, à adapter à ton contexte.(attention au type des variables).

    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
    Sub FitreAutoDatesurDVP()
    Dim lngNoCol As Long
    Dim strFormatbase As String
    Dim vntCrit1 As String
    Dim vntCrit2 As String
     
    lngNoCol = 1 'à 73 chez toi
    vntCrit1 = ">=" & CDec(CDate("01/01/2010"))
    vntCrit2 = "<=" & CDec(CDate("31/12/2010"))
    strFormatbase = Cells(2, 1).NumberFormat 'récupère le format de la 2ème cellule, la 1ère étant le titre
    Columns(lngNoCol).NumberFormat = "General" ' passe en numéros de série
    Selection.AutoFilter Field:=lngNoCol, Criteria1:=vntCrit1, Operator:=xlAnd, Criteria2:=vntCrit2  ' filtre nos données
    Columns(lngNoCol).NumberFormat = strFormatbase ' rebascule en format d'origine, mais on peut changer
    ' Attention, la partie non filtrée des données reste en N° de série, à traiter ensuite selon le contexte.
    'Fonctionne même si les formats de dates ne sont pas homogènes dans la colonne, mais les uniformisera en final.
    End Sub
    cordialement,

    Didier

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

Discussions similaires

  1. [XL-2007] recherche d'element dans excel, avec une macro
    Par astroflo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 18/01/2012, 09h33
  2. [SSRS] [2K5] filtrer sur des dates
    Par geof dans le forum SSRS
    Réponses: 2
    Dernier message: 09/09/2010, 14h35
  3. Gestion des dates sous Excel avec les microsecondes
    Par fredppp dans le forum Framework .NET
    Réponses: 1
    Dernier message: 15/12/2009, 22h36
  4. [A-03] Test sur des dates dans des textBox
    Par moilou2 dans le forum IHM
    Réponses: 3
    Dernier message: 27/10/2008, 13h39
  5. Opération sur des heures dans Excel
    Par mirascheat dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 15/12/2005, 10h34

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