Autres Extraire ligne excel avec trie sans perdre index initial

FOUQUET Yves

XLDnaute Occasionnel
Bonsoir a toutes et tous.
Mon problème actuel c'est de pouvoir sélectionner des lignes comptables dans un userform sachant qu’elles ont été triées avant en fonction du compte bancaire de rattachement. (4 comptes ou livret et la caisse à gérer)
J'ai essayé de créer une feuille avec les deux index collectés pour avoir une concordance des index mais bon là je craque...

Bonne soirée et merci encore de votre aide.
 

FOUQUET Yves

XLDnaute Occasionnel
Bonsoir,
J'explique mon soucis.
J'ai un tableau Excel avec 150 lignes de compta. Certaines sont pointées comme vu sur releve banque d'autres (minoritaire) comme non pointées.
Je fais donc un trie sur ces lignes afin d'extraire les non pointees dans combobox. Ensuite l'idée est de cliquer sur une de ses lignes, au regard du relevé banque, de la pointe comme vue, et de l'enregistrer.
Tout cela fonctionnerai sauf que les indexés des lignes du combobox ne sont plus sur l'index de la feuille. En d'autres termes ce n'est pas la bonne ligne qui se modifie. Grrrrrrrrr
J'ai essayé de générer une feuille avec concordance des indexs mais que ni ni. Conclusion je suis en panne....

Si quelqu'un a une idée, peut monter le tableur dans l'userforme et modifier a partir de la mais j'ai lu que ce n'était pas possible!

A vous lire.
Merci d'avance...
 

Staple1600

XLDnaute Barbatruc
Re

Tu n'as jamais joué au flipper dans les bars?
(Quand tu faisais Tilt!, ce message s'affichait:
same player shoot again ;))

Et cette phrase n'est pas sorti de la cuisse de Teresa May ;)
Une nouvelle discussion avec un classeur exemple fourni par le demandeur

Mais bon, en clair, je voulais te dire que si tu joignais un fichier Excel exemple dans cette nouvelle discussion, cela facilitera la résolution de ta question ;)
 

FOUQUET Yves

XLDnaute Occasionnel
D'abord le code: et on ne m’engueule pas!

VB:
Dim nom_banq_select As String
Dim ligne As Integer
Dim i As Integer
Dim j As Integer


Dim nom_banq As String
Dim date_op As Date
Dim compt_gene As String
Dim libelle As String
Dim montant As Currency
Dim libelle2 As String
Dim justif As String
Dim solde As String
Dim non_just As Currency
Dim mont_comb As String
Dim mont_comb2 As Currency
Dim result_banq As String
Dim ligne2 As Integer

Private Sub UserForm_Initialize()
'================ AFFICHER SELECTIONNER BANQUE DANS Combobox1 ============================================
Set Ws = Sheets("Aides3")
With Me.ComboBox1
    For j = 2 To Ws.Range("H" & Rows.Count).End(xlUp).Row
      .AddItem Ws.Range("H" & j)
    Next j
End With
TextBox14 = (0)
End Sub
'------------------------------------------------------------------------
Private Sub ComboBox1_Change()    'si ligne initiale combobox1 change ...

solde = 0
TextBox13.Value = 0
nom_banq_select = ComboBox1.Text

Sheets.Add.Name = "concord"

Set Ws = Sheets("En cours") 'Avec la feuille "En cours"  fait....
justif = "x"
non_just = 0
ligne = 0
    For j = 1 To Ws.Range("B" & Rows.Count).End(xlUp).Row
      nom_banq = Sheets("En cours").Range("B" & j)
      With Sheets("concord")
      .Range("A" & j).Value = j                 'Insére le numero d'index dans la colonne A feuille concord
      End With
      If nom_banq_select = nom_banq Then        ' -- je trie sur la base des écritures non JUSTIFIEES avec la banque -----
                           
            justif = Sheets("En cours").Range("F" & j)
                   
            If justif = "," Then                ' la cellule est marquée "," quand elle n'est pas justifiée avec la banque
            montant = Sheets("En cours").Range("E" & j)
            non_just = non_just + montant       ' je cumule le montant des écritures pour affichage dans userform
            ligne = ligne + 1
            With Sheets("concord")
            .Range("B" & j).Value = ligne                'Insére le numero d'index dans la colonne A feuille concord
            End With
                     
            End If
     TextBox13.Value = Format(non_just, "currency")
   
     End If
    If j = 569 Then Exit For
    Next
   

'----------------------- Affecte le solde du comptes sélectionné dans textbox  "à affiner à partir d'une variable" ---------------------------------------
With ComboBox1()
     If nom_banq_select = "CAISSE" Then
    solde = Sheets("En cours").Range("E" & 624)
    TextBox12.Value = Format(solde, "currency") '-- Solde du compte ---
    result_banq = solde - non_just
    TextBox14.Value = Format(result_banq, "currency")
    End If

    If nom_banq_select = "COMPTE COURANT CREDIT MARITIME" Then
    solde = Sheets("En cours").Range("E" & 625)
    TextBox12.Value = Format(solde, "currency") '-- Solde du compte ---
    result_banq = solde - non_just
    TextBox14.Value = Format(result_banq, "currency")
    End If
   
    If nom_banq_select = "LIVRET CREDIT MARITIME" Then
    solde = Sheets("En cours").Range("E" & 626)
    TextBox12.Value = Format(solde, "currency") '-- Solde du compte ---
    result_banq = solde - non_just
    TextBox14.Value = Format(result_banq, "currency")
    End If
   
    If nom_banq_select = "COMPTE COURANT CREDIT MUTUEL" Then
    solde = Sheets("En cours").Range("E" & 627)
    TextBox12.Value = Format(solde, "currency") '-- Solde du compte ---
    result_banq = solde - non_just
    TextBox14.Value = Format(result_banq, "currency")
    End If
   
    If nom_banq_select = "LIVRET CREDIT MUTUEL" Then
    solde = Sheets("En cours").Range("E" & 628)
    TextBox12.Value = Format(solde, "currency") '-- Solde du compte ---
    result_banq = solde - non_just
    TextBox14.Value = Format(result_banq, "currency")
   
    End If
End With
' ------------- si je selectionne dans la liste du combobox des non_justifiées, affiche infos de la ligne ----------------------------------

justif = "x"

Set Ws = Sheets("En cours")          '------  affecte les lignes non justifié à la combobox2 par le montant
With Me.ComboBox2
    For j = 8 To Ws.Range("E" & Rows.Count).End(xlUp).Row
    nom_banq = Sheets("En cours").Range("B" & j)
    If nom_banq_select = nom_banq Then
    justif = Sheets("En cours").Range("F" & j)
        If justif = "," Then .AddItem Ws.Range("E" & j)
        End If
    'AddItem Ws.Range("E" & j)
    If j = 569 Then Exit For    ' 569  dernière ligne à lire
   
    Next j
End With
End Sub
'-----------------------------------------------------------
Private Sub ComboBox2_Change() ' si selection dans combobox2 affiche les textbox

i = 0

Set Ws = Sheets("En cours")     'Attention ce nom doit correspondre au nom de votre ONGLET


' Me.ComboBox2.ListIndex = 19 'Sheets("concord").Range("A" & j)
If Me.ComboBox2.ListIndex = -1 Then Exit Sub

If Me.ComboBox2.ListIndex > 0 Then ligne = Sheets("concord").Range("A" & j)  '=============== a regler-------------

'ligne = Me.ComboBox2.ListIndex
TextBox17 = j
For i = 1 To 10
Me.Controls("TextBox" & i) = Ws.Cells(ligne, i)  ' ET C'EST LA QUE JE PERDS MON INDEX DE LA FEUILLE, normal!
Next i

End Sub
'---
'================================================================================
'Correspond au programme du bouton MODIFIER
Private Sub CommandButton2_Click()
i = 0

If MsgBox("Etes-vous certain de vouloir pointer cette écriture ?", vbYesNo, "Demande de confirmation") = vbYes Then
montant = 0
  If Me.ComboBox2.ListIndex = -1 Then Exit Sub 'On sort si pas de sélection
        For i = 1 To 10
           If Me.Controls("TextBox" & i).Visible = True Then
           Ws.Cells(ligne, 6) = Me.Controls("TextBox" & 6)  '--- modifie colonne justif
                                                            ' ET C'EST LA QUE JE PERDS MON INDEX DE LA FEUILLE, normal!
                                                            ' et je ne modifie pas la bonne ligne dans la feuille.
           TextBox17 = ligne
           End If
        Next i
    montant = TextBox13 - Sheets("En cours").Range("E" & ligne)
    TextBox13.Value = Format(montant, "currency")
   
    TextBox12.Value = Format(solde, "currency")
    result_banq = TextBox12.Value - non_just
    TextBox14.Value = Format(result_banq, "currency")
  End If 'fin de la condition

End Sub
 

Statistiques des forums

Discussions
311 722
Messages
2 081 930
Membres
101 843
dernier inscrit
Thaly