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 :

Dispatcher par onglet l'ensemble des données BDD à partir d'un critère [XL-2007]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 55
    Par défaut Dispatcher par onglet l'ensemble des données BDD à partir d'un critère
    Bonjour à tous,

    Je cherche à dispatcher une base de donnée par onglet grâce à un critère.
    Dans mon cas la derniere colonne.

    J'ai trouvé le moyen grâce au tableau croisé, une fois fait, avec en filtre de rapport il suffit de faire "afficher les filtres de rapport" on a autant d'onglet que ce trouve de critère. En l’occurrence, autant d'onglet que d'agence pour mon cas.

    J'ai deux problème à ce principe:
    * c'est qu'un TCD est lourd, j'ai prêt de 90 colonnes ce qui rend la mise en page du TCD assez complexe et peu lisible mais néanmoins possible.
    *Il y a un problème de confidentialité, l'agence est sélectionnée en filtre de rapport, chaque utilisateur de son fichier pourrait sélectionner une autre agence car il garde tout en mémoire.

    L'avantage :
    *peut etre automatisé
    *met en nom d'onglet le nom de l'agence

    Je cherche donc à récupérer l'ensemble des informations liées à une agence(dernière colonne) comme si un filtre était fait.
    Comme lorsqu'on fait connexion de donnée et qu'on a le choix entre récupérer le donnée en TCD ou tableau. Mon cas serait plutot en tableau.

    Mon but final après est de dispatcher chaque onglet vers un dossier précis(code trouvé).
    Pour ce que ça intéresse ci dessous le code.

    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
    33
    34
    Sub Macro1()
    '
    ' Macro1 Macro
    ' Macro enregistrée le 16/12/2011 par fl170417
    '
    '
    Dim vnom, vdir As String
    For Each Sheet In Sheets
    Sheet.Select
    vnom = ActiveSheet.Name
    Cells.Select
    Selection.Copy
    Workbooks.Add
    ActiveSheet.Paste
    Application.CutCopyMode = False
    Application.DisplayAlerts = False
    ChDir "N:\"
    'choix du repertoire en fonction du nom agence
    Select Case vnom
    Case "Agence1": vdir = "Est\"
    Case "Agence2": vdir = "Nord\"
    Case "Agence3": vdir = "Nord\"
    Case "Agence4": vdir = "Est\"
    Case "Agence5": vdir = "Est\"
    End Select
    ActiveWorkbook.SaveAs Filename:="N:\" & vdir & vnom & " Période du " & Format(Date, "mm-yyyy") & ".xls", FileFormat:=xlNormal, _
    Password:="", WriteResPassword:="", ReadOnlyRecommended:=False, _
    CreateBackup:=False
    ActiveSheet.Name = vnom
     
    ActiveWindow.Close savechanges = True
    Application.DisplayAlerts = True
    Next
    End Sub

    En vous remerciant pour l'aide que vous pourriez m'apporter.

    Anthooooony
    Fichiers attachés Fichiers attachés

  2. #2
    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, via un filtre automatique sur la colonne concernée
    Je n'ouvre pas les fichiers en PJ.

    Liste est une plage nommée de l'ensemble des données
    Feuil2 est le CodeName à adapter pour chaque agence

    Ceci n'est q'un brouillon et nécessitera une adaptation de ta part, mais le principe est là.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Option Explicit
     
    Sub Tst()
    Dim Rng As Range
        ' A adapter à ton contexte pour Field ( colonne de filtrage ) et Criteria ( nom d'agence  ? )
     
        [liste].AutoFilter Field:=5, Criteria1:="1"
        Set Rng = Application.[liste].SpecialCells(xlCellTypeVisible)   
        Feuil2.Cells.Clear
        Rng.Copy Feuil2.Range("A1")
    End Sub

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 55
    Par défaut
    Merci de ton retour !!

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

Discussions similaires

  1. [MySQL] bug de mon code pour afficher des donnes BDD a partir de l'id transmise
    Par gael-abdelhadi dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 20/03/2011, 12h56
  2. L'ensemble des données n'est pas en mode Edition ou Insertion
    Par devilbyme dans le forum Composants VCL
    Réponses: 5
    Dernier message: 27/09/2010, 19h17
  3. Réponses: 1
    Dernier message: 28/03/2010, 10h06
  4. Réponses: 5
    Dernier message: 27/06/2008, 14h48
  5. Réponses: 7
    Dernier message: 24/02/2006, 12h32

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