Accéder au contenu principal

Trier une ListBox Access

Lorsqu'on a une ListBox dont la SourceType est une ValueList, comment la trier ?
Réponse ci-dessous, avec possibilité de trier sur n'importe quelle colonne, en mode numérique ou alpha.
Sub SortListBox(ByRef lstBox As ListBox, iCol As Integer, Optional isNum As Boolean = False)

'sorts the value list of a listbox on any column
'numerical col. can be sorted numerically or alpha
'sorting algorithm is probably not the most efficient
'Copyleft: Patrick Honorez - www.idevlop.com
Dim vaItems As Variant, cols As Integer
Dim i As Long, j As Long, k As Integer
Dim vTemp As String, IsSwapped As Boolean
Dim isSmaller As Boolean
On Error GoTo 0
'Put the items in a variant array
vaItems = Split(lstBox.RowSource, ";")
cols = lstBox.ColumnCount
Do
IsSwapped = False
For i = 0 To lstBox.ListCount - 2
j = i + 1
If isNum Then
isSmaller = Val(vaItems(i * cols + iCol - 1)) > _
Val(vaItems(j * cols + iCol - 1))
Else
isSmaller = vaItems(i * cols + iCol - 1) > _
vaItems(j * cols + iCol - 1)
End If
If isSmaller Then
For k = 0 To cols - 1
'swap row i and row j
IsSwapped = True
vTemp = vaItems(i * cols + k)
vaItems(i * cols + k) = (vaItems(j * cols + k))
vaItems(j * cols + k) = vTemp
Next k
End If
Next i
Loop While IsSwapped
'Add the sorted array back to the listbox
lstBox.RowSource = Join(vaItems, ";")
Me.Repaint
End Sub

Commentaires

Posts les plus consultés de ce blog

Champs obligatoires dans un formulaire Access

Comment rendre des champs obligatoires dans un formulaire Access ? La réponse la plus évidente est de modifier le design de la table et d'assigner au paramètre Required la valeur True. L'ennui de cette méthode est que le message d'erreur d'Access n'est pas très convivial et ne spécifie pas quel champ a déclenché l'erreur. Plutôt que d'écrire une routine de gestion d'erreur complexe, il y a une solution toute simple: affecter la valeur Faux à la propriété  Required du champ, Validation Rule: Is Not Null Validation Text: le texte à afficher, ex: "Code Postal obligatoire" ..et le tour est joué. Cette astuce vient de l'excellent Allen Browne, dont le site (en anglais) regorge d'informations utiles sur Access. ps: je n'ai pas sous la main de version française d'Access pour la traduction des propriétés, désolé...

ROW_NUMBER OVER PARTITION en Access

Ceux qui ont l'habitude de travailler avec une "grosse" base données comme SQL Server / Oracle / PostGreSQL, sont parfois frustrés face à certaines lacunes du SQL d'Access.   Prenons par exemple: ROW_NUMBER() OVER PARTITION, dont l'absence rend certaines requêtes très compliquées.   J'ai donc écrit une petite fonction VBA qui peut être appelée depuis un query Access et qui simulera assez bien ce ROW_NUMBER() OVER PARTITION.   Notez que ceci ne fonctionnera pas correctement dans une vue ou un formulaire interactif. Par contre comme source d'un rapport ou d'un export Excel, c'est impeccable.   En pratique il est préférable d'initialiser la fonction avec une chaîne de caractères "improbable" avant de lancer le rapport, comme indiqué dans le code.