Salut,
Je travail sur Excel 2003 , pour remplir ma "Liste 1 " appartir de la "Base A" ,en inscrivant l'Année Scolaire dans la cellule de saisie"H5" ,j'ai fais le code suivant qui fonction bien . Mais peut- on simplifier l'écriture de 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
35
36
37
38
39
40
41
42
43
Private Sub Worksheet_Change(ByVal Target As Range)
Dim x, y As Integer
 
If (Target.Address = "$H$5") And Not IsEmpty(Target.Value) Then
    With Application.ThisWorkbook
        .Sheets("Liste1").Range("A9:I65000").ClearContents
 
        x = 3
        y = 8
 
        While (Sheets("Base A").Range("H" & x) <> "")
            If Sheets("Base A").Range("H" & x).Value = Sheets("Liste1").Range("H5").Value Then
                Sheets("Liste1").Range("A" & y).Value = Sheets("Base A").Range("A" & x).Value
                Sheets("Liste1").Range("B" & y).Value = Sheets("Base A").Range("B" & x).Value
                Sheets("Liste1").Range("C" & y).Value = Sheets("Base A").Range("C" & x).Value
                Sheets("Liste1").Range("D" & y).Value = Sheets("Base A").Range("D" & x).Value
                Sheets("Liste1").Range("E" & y).Value = Sheets("Base A").Range("E" & x).Value
                Sheets("Liste1").Range("F" & y).Value = Sheets("Base A").Range("F" & x).Value
                Sheets("Liste1").Range("G" & y).Value = Sheets("Base A").Range("G" & x).Value
                Sheets("Liste1").Range("H" & y).Value = Sheets("Base A").Range("I" & x).Value
                Sheets("Liste1").Range("I" & y).Value = Sheets("Base A").Range("J" & x).Value
                y = y + 1
            End If
 
            x = x + 1
        Wend
 
    End With
 
z = 8
While (Sheets("Liste1").Range("A" & z) <> "")
    z = z + 1
Wend
 
Sheets("Liste1").Select
Range("A8:I" & z).Select
 
Selection.Sort Key1:=Range("A8"), Order1:=xlAscending, _
    OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
 
End If
 
End Sub
Merci.
Cordialement