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 :

Affichage entête avec une boucle


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2012
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2012
    Messages : 32
    Par défaut Affichage entête avec une boucle
    bonjour je suis débutant en VBA ,et je voudrais faire une procédure ou fonction AFFICHAGE qui me qui me permetrait de répéter 6 fois (3 en haut et 3 en dessous) dans la méme feuille excel une en_tête de 4 éléments (NOM ,Prénom,AGE,Nationalité) et un bordure qui varie en fonction des sous élemnts que composent ces en têtes. Merci d'avance pour votre soutient

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 99
    Par défaut
    Bonjour Gibba 88 le forum
    un peu light tes explications, c'est quoi ton histoire de bordures différentes??
    de plus la série Nom Prenom age nationalité tu veux les mettre comment?
    A1B1C1D1 et là suivante E1 F1 G1 H1 mais la suivante de série tu la veut ou??
    a te relire
    a+
    papou

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2012
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2012
    Messages : 32
    Par défaut
    oui papou c'est a peu prés ca A4B4C4D4---G4H4I4J4---M4N4O4P4; A24B24C24D24---G24H24I24J24---M24N24O24P24, Mercie d'avance

    enfaite j'ai pris "Nom,Pronom,Age...." pour ne pas trop vous embrouiller avec mon programme .mais voila mon vrai procédure affichage .mais j'aimeriais le simplifié en un code simple de sorte à ne pas réecrire 6 fois l'en tête dans la méme procédure
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
     
    'Proprietés
    Sub Affichage_Entête()
    'sélection de la feuille d'affection
    Sheets("feuil1").Select
    'propreté Police
    Range("a4:F4").Font.Bold = True
    Range("a4:F4").Font.Size = 13
    Range("a4:F4").Borders.Value = 0
    'propreté Police
    Range("H4:M4").Font.Bold = True
    Range("H4:M4").Font.Size = 13
    Range("H4:M4").Borders.Value = 0
    'propreté Police
    Range("O4:T4").Font.Bold = True
    Range("O4:T4").Font.Size = 13
    Range("O4:T4").Borders.Value = 0
    'propreté Police
    Range("a24:F24").Font.Bold = True
    Range("a24:F24").Font.Size = 13
    Range("a24:F24").Borders.Value = 0
    'propreté Police
    Range("H24:M24").Font.Bold = True
    Range("H24:M24").Font.Size = 13
    Range("H24:M24").Borders.Value = 0
    'propreté Police
    Range("O24:T24").Font.Bold = True
    Range("O24:T24").Font.Size = 13
    Range("O24:T24").Borders.Value = 0
     
     
    With ActiveSheet
        .Cells(3, 1) = "DEFAUT PHASE"
        .Cells(3, 7) = "DEFAUT HOMOPOLAIRE"
        .Cells(3, 13) = "CYCLE REENCLENCHEUR"
        .Cells(23, 1) = "DEFAUT DOUBLE"
        .Cells(23, 7) = "TEST GRADIN"
        .Cells(23, 13) = "RSE"
    End With
    'en-tête
    With ActiveSheet
        .Cells(4, 1) = "Nom"
        .Cells(4, 2) = "Nominale"
        .Cells(4, 3) = "Unités"
        .Cells(4, 4) = "Réel"
        .Cells(4, 5) = "Eval"
     
        .Cells(4, 7) = "Nom"
        .Cells(4, 8) = "Nominale"
        .Cells(4, 9) = "Unités"
        .Cells(4, 10) = "Réel"
        .Cells(4, 11) = "Eval"
     
        .Cells(4, 13) = "Nom"
        .Cells(4, 14) = "Nominale"
        .Cells(4, 15) = "Unités"
        .Cells(4, 16) = "Réel"
        .Cells(4, 17) = "Eval"
     
        .Cells(24, 1) = "Nom"
        .Cells(24, 2) = "Nominale"
        .Cells(24, 3) = "Unités"
        .Cells(24, 4) = "Réel"
        .Cells(24, 5) = "Eval"
     
        .Cells(24, 7) = "Nom"
        .Cells(24, 8) = "Nominale"
        .Cells(24, 9) = "Unités"
        .Cells(24, 10) = "Réel"
        .Cells(24, 11) = "Eval"
     
        .Cells(24, 13) = "Nom"
        .Cells(24, 14) = "Nominale"
        .Cells(24, 15) = "Unités"
        .Cells(24, 16) = "Réel"
        .Cells(24, 17) = "Eval"
    End With
    End Sub

  4. #4
    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 168
    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 168
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Une idée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     Dim r As Long
     With ActiveSheet
      For r = 1 To 200 Step 6
        .Cells(4, r) = "Nom"
        .Cells(4, r + 1) = "Nominale"
        .Cells(4, r + 2) = "Unités"
        .Cells(4, r + 3) = "Réel"
        .Cells(4, r + 4) = "Eval"
      Next
     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

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 99
    Par défaut
    Bonjour Gibba88 le forum
    voilà une macro pour faire ce que tu demandes
    a+
    papou
    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
    Sub Composer()
        Dim i&, a As Variant, n&, x&
        With Feuil1
            For i = 3 To 24 Step 20
                For Each a In Array("Nom", "Nominale", "Unités", "Réels", "Eval")
                    For n = 1 To 16 Step 6
                        .Cells(i + 1, n + x) = a
                        Next n
                    x = x + 1
                Next a
                x = 0
            Next i
            .Cells(3, 1) = "DEFAUT PHASE": .Range(.Cells(3, 1), .Cells(3, 5)).Merge: .Range(.Cells(3, 1), .Cells(3, 5)).HorizontalAlignment = xlCenter
            .Cells(3, 7) = "DEFAUT HOMOPOLAIRE": .Range(.Cells(3, 7), .Cells(3, 11)).Merge: .Range(.Cells(3, 7), .Cells(3, 11)).HorizontalAlignment = xlCenter
            .Cells(3, 13) = "CYCLE REENCLENCHEUR": .Range(.Cells(3, 13), .Cells(3, 17)).Merge: .Range(.Cells(3, 13), .Cells(3, 17)).HorizontalAlignment = xlCenter
            .Cells(23, 1) = "DEFAUT DOUBLE": .Range(.Cells(23, 1), .Cells(23, 5)).Merge: .Range(.Cells(23, 1), .Cells(23, 5)).HorizontalAlignment = xlCenter
            .Cells(23, 7) = "TEST GRADIN": .Range(.Cells(23, 7), .Cells(23, 11)).Merge: .Range(.Cells(23, 7), .Cells(23, 11)).HorizontalAlignment = xlCenter
            .Cells(23, 13) = "RSE": .Range(.Cells(23, 13), .Cells(23, 17)).Merge: .Range(.Cells(23, 13), .Cells(23, 17)).HorizontalAlignment = xlCenter
            End With
    End Sub

  6. #6
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Autre proposition
    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
    Sub ComposerBis()
    Dim i As Integer, j As Integer
    Dim Titre, Entete
    Dim k As Byte
     
    Entete = Array("Nom", "Nominale", "Unités", "Réels", "Eval")
    Titre = Array("DEFAUT PHASE", "DEFAUT HOMOPOLAIRE", "CYCLE REENCLENCHEUR", "DEFAUT DOUBLE", "TEST GRADIN", "RSE")
    With Feuil2
        For i = 3 To 24 Step 20
            For j = 1 To 16 Step 6
                With .Cells(i, j)
                    .Resize(1, 5).Merge
                    .Value = Titre(k)
                    .Offset(1, 0).Resize(1, 5) = Entete
                    With .Resize(2, 5)
                        .HorizontalAlignment = xlCenter
                        .Borders.Value = 0
                        With .Font
                            .Bold = True
                            .Size = 13
                        End With
                    End With
                End With
                k = k + 1
            Next j
        Next i
    End With
    End Sub

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

Discussions similaires

  1. [2.x] [Twig][Formulaire] Problème d'affichage avec une boucle
    Par ccomarvin dans le forum Symfony
    Réponses: 1
    Dernier message: 31/01/2013, 10h57
  2. [MySQL] affichage d'une liste avec une boucle while
    Par Invité dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 29/01/2007, 20h19
  3. Comment initialiser une liste de composants avec une boucle ?
    Par EricSid dans le forum Composants VCL
    Réponses: 5
    Dernier message: 06/04/2005, 18h46
  4. Réponses: 1
    Dernier message: 30/03/2005, 15h50
  5. Generer des noms de variables avec une boucle
    Par moutanakid dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/07/2004, 17h45

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