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 :

Problème dans boucle for et if [XL-2007]


Sujet :

Macros et VBA Excel

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2013
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2013
    Messages : 54
    Par défaut Problème dans boucle for et if
    Bonjour à tous,
    Dans la pièce jointe ci-dessous, vous trouverez un exemple de planning avec un userform. Ce que je veux faire, c'est permettre de rentrer les congés d'un technicien. En gros, je choisis le technicien, les dates de début et fin de ses congés, je clique sur "ok" et les cellules correspondant à ses congés se remplissent. Mais mon code ne fonctionne pas tout à fait... Il remplit toutes les lignes du technicien sans se préoccuper des dates. Le voici :
    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
     
    Private Sub BT_Arrets_Conges_Click()
     
        If Not IsDate(TB_Dbt.Value) Or Not IsDate(TB_Fin.Value) Then
     
            LB_Attention.Visible = True
     
        Else
     
            LB_Attention.Visible = False
            Form_Eric_2.Hide
     
            Dim dbt, fin As Date
            Dim i, j, DernLigne As Integer
     
            dbt = TB_Dbt.Value
            fin = TB_Fin.Value
            DernLigne = Range("B" & Rows.Count).End(xlUp).Row
     
            For i = 6 To DernLigne Step 1
                If Cells(i, 4).NumberFormat = "d-mmm" Then
                    For j = 4 To 8 Step 1
                        If dbt <= Cells(i, j).Value <= fin Then
                            Dim k As Integer
                            k = i + 1
                            While Cells(k, 2).Value <> CB_Collaborateur.Value
                                k = k + 1
                            Wend
                            With Cells(k, j)
                                .Value = CB_Type.Value
                                .Interior.Color = vbBlue
                            End With
                            With Cells(k + 1, j)
                                .Value = CB_Type.Value
                                .Interior.Color = vbBlue
                            End With
                        End If
                    Next
                End If
            Next
     
        End If
     
    End Sub
    Voyez vous ce qui ne va pas ? Merci de votre aide !
    Images attachées Images attachées   

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

Discussions similaires

  1. Problème de soustraction dans Boucle For each
    Par athos7776 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 14/04/2011, 05h46
  2. Problème d'index dans boucle for
    Par cocacola0589 dans le forum ActionScript 3
    Réponses: 1
    Dernier message: 09/02/2010, 18h22
  3. problème dans boucle for de lecture de fichier ini
    Par chourmo dans le forum Delphi
    Réponses: 3
    Dernier message: 06/07/2006, 09h31
  4. [JLabel] JLabel dans boucle for
    Par clairenes dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 06/01/2006, 00h47
  5. [XML-XPATH] Problème dans un for each
    Par stailer dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 26/12/2005, 12h11

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