Bonjour à toutes et à tous,

Grâce à l'aide précieuse de Mercatog j'ai réussi à faire une recherche dans un userform. voici 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
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
Private Sub BtnRecherche_Click()
Dim c As Range
Dim LastLig As Long, Lig As Long
Dim sLigne As String
 
 'Appel de la procédure de déblocage.
    Call p_Debloque
 
 
    'Gestion de l'état des boutons.
    Call p_NewModif
 
 
 
 
If Me.txtrecherche.Value <> "" Then
    With Sheets("liste")
        LastLig = .Cells(Rows.Count, "E").End(xlUp).Row
        Set c = .Range("E2:E" & LastLig).Find(Me.txtrecherche.Value, LookIn:=xlValues, lookat:=xlPart)
        If Not c Is Nothing Then
            Lig = c.Row 'dans Lig on a la ligne de la donnée trouvée
 
            libNave.Caption = "enregistrement : " & Lig - 1 & "/" & Lig
 
    Me.libCode.Caption = .Range("A" & Lig)
    Me.txtCreateur = .Range("B" & Lig)
    Me.txtDateCreation = .Range("D" & Lig)
    Me.cmbOriente = .Range("C" & Lig)
    Me.txtNom = .Range("E" & Lig)
    Me.txtPrenom = .Range("F" & Lig)
    Me.OptionFemme = .Range("G" & Lig)
    Me.OptionHomme = .Range("G" & Lig)
    Me.txtDateNaiss = .Range("H" & Lig)
    Me.txtAge = .Range("I" & Lig)
    Me.txtLieuNaiss = .Range("J" & Lig)
    Me.cmbNationalite = .Range("K" & Lig)
    Me.txtPays = .Range("L" & Lig)
    Me.txtNSS = .Range("M" & Lig)
    Me.CmbSituationFamille = .Range("N" & Lig)
    Me.txtMemo1 = .Range("O" & Lig)
    Me.txtNomRef = .Range("P" & Lig)
    Me.cmbOrganismeR = .Range("Q" & Lig)
    Me.txtPhone1 = .Range("R" & Lig)
    Me.txtNomRef2 = .Range("S" & Lig)
    Me.cmbOrganismeR2 = .Range("T" & Lig)
    Me.txtPhone2 = .Range("U" & Lig)
    Me.cmbRevenu = .Range("V" & Lig)
    Me.OptionOui = .Range("W" & Lig)
    Me.OptionNon = .Range("W" & Lig)
    Me.cmbdomiciliation = .Range("X" & Lig)
    Me.Txtmemo2 = .Range("Y" & Lig)
    Me.txtNomProt = .Range("Z" & Lig)
    Me.cmbOrganismeProt = .Range("AA" & Lig)
    Me.txtPhone3 = .Range("AB" & Lig)
    Me.Optiontutelle = .Range("AC" & Lig)
    Me.Optioncuratelle = .Range("AC" & Lig)
    Me.OptionMedoui = .Range("AD" & Lig)
    Me.OptionMednon = .Range("AD" & Lig)
    Me.txtmemo3 = .Range("AE" & Lig)
    Me.cmbOrientationMed = .Range("AE" & Lig)
    Me.CmbProvenance = .Range("AF" & Lig)
    Me.CmbsituationErrance = .Range("AH" & Lig)
    Me.Optionmoins1S = .Range("AI" & Lig)
    Me.Optionmoins1M = .Range("AI" & Lig)
    Me.Option1a6M = .Range("AI" & Lig)
    Me.Option6M1A = .Range("AI" & Lig)
    Me.Option1a2A = .Range("AI" & Lig)
    Me.Option2a5A = .Range("AI" & Lig)
    Me.Option5APlus = .Range("AI" & Lig)
    Me.OptionNSP = .Range("AI" & Lig)
    Me.TxtParcoursA = .Range("AJ" & Lig)
    Me.TxtObjectifEx = .Range("AK" & Lig)
    CmbPieceIdentite = .Range("AL" & Lig)
    Me.TxtDateExpi = .Range("AM" & Lig)
    Me.OptionNul = .Range("AN" & Lig)
    Me.OptionRegG = .Range("AN" & Lig)
    Me.Optioname = .Range("AN" & Lig)
    Me.OptionRien = .Range("AN" & Lig)
    Me.Optioncmuc = .Range("AO" & Lig)
    Me.OptionNC = .Range("AO" & Lig)
    Me.OptionAvert = .Range("AP" & Lig)
    Me.OptionExclu = .Range("AP" & Lig)
    Me.OptionFinSejour = .Range("AP" & Lig)
    Me.TxtMemo4 = .Range("AQ" & Lig)
    Me.CmbOrientation = .Range("AR" & Lig)
 
                    Set c = Nothing
        Else
            MsgBox Me.txtrecherche.Value & " non trouvé"
        End If
    End With
 
Else
    MsgBox "renseignez le texte à chercher"
End If
End Sub
Voici mon problème : si je cherche M. Delarue les infos de cette personne s'affichent normalement. Mais lorsque je fais une modif sur cette fiche, qui est le 3ème enregistrement,après validation les modif s'appliquent systématiquement à la première ligne. Je perds donc toujours ma premiere ligne d'enregistrement et la ligne qui doit être modifiée ne l'est pas.

Pouvez-vous m'aider svp

Merci d'avance et bonne journée