Accéder au contenu principal

Erreurs Excel courantes: les listes

Ayant du examiner d'innombrables tableaux Excel dans diverses organisations, je voudrais reprendre  quelques erreurs de design parmi les plus courantes. Je commencerai par les listes.

Une liste doit être en un seul bloc

Pour profiter des avantages d'Excel en matière de gestion de listes, celle-ci ne doivent pas comporter de "trous" entre les lignes, ni d'espace entre la ligne de titre et la suivante. Sans cela, tris, filtres, sous-totaux automatiques, et tableaux croisés dynamiques (Pivot tables) ne fonctionneront pas correctement.
Si vous voulez séparer visuellement le titre du reste du tableau, il suffit d'agrandir la hauteur de la ligne de titre.

Eviter les sous-totaux "manuels"

Excel comporte des options pour ajouter et retirer des sous-totaux dans une liste. Utiliser ces options évite les problèmes lors de tris ultérieurs. Ces options se trouvent dans le menu Data, Subtotals (Données, Sous-totaux).

Mettre le total général AU-DESSUS de la liste

Alors que nous sommes généralement habitués à mettre le total d'une colonne en bas de celle-ci, je trouve beaucoup plus pratique en Excel de mettre ces totaux EN HAUT de la colonne, au dessus des titres. Pourquoi ?
  • Cela permet de figer les 3 premières lignes de la feuille, et de se déplacer verticalement dans de longues listes tout en continuant à voir les titres ET les totaux.
  • Si on s'arrange pour que la formule de total de la colonne inclue un bon nombre de ligne vides, il suffira d'ajouter de nouvelles lignes en bas de la liste pour que ces lignes soit prises en compte. Avec un total en BAS de liste, il est nécessaire d'insérer des lignes et de vérifier qu'elle soit prise en compte dans le total
  • en cas de tri, le total n'est pas impacté ni déplacé

Commentaires

Posts les plus consultés de ce blog

Simuler un COUNT DISTINCT avec Access

Le SQL disponible dans les requêtes Access ne dispose pas de l'instruction COUNT DISTINCT, qui permettrait par exemple, de compte combien de clients différents ont commandé, année par année. Ce prédicat, qui est présent dans SQL Server, peut être simulé de diverses manières, plus ou moins lourdes et plus ou moins efficaces. Mais la méthode probablement la plus performante est d'utiliser une requête CROSSTAB un peu particulière. Voici  un exemple sur la base Northwind (ou Comptoirs avec les versions françaises d'Access), dans lequel on va décompter le nombre de clients différents par année, ainsi que le nombre total de commandes: TRANSFORM Count(*) AS Dist SELECT Year([OrderDate]) AS Yr, Count(([Dist])) AS DistCustomers, Count(OrderId) AS NumOrders FROM Orders AS o GROUP BY Year([OrderDate]) PIVOT CustId In (null); Pour la voir en action, vous pouvez créer une nouvelle requête dans Northwind, l'afficher en mode SQL, et y coller le code ci-dessus. Ce type de requ

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é...

Remplir une ListBox Access

Pour remplir une ListBox MS Access avec des données provenant d'un recordset, il suffit généralement de définir une rowSourceType = Table et de donner le nom de la table ou de la requête. Mais dans certains cas, il peut être préférable de fournir ces valeurs sous forme d'une ValueList. C'est le travail de la fonction ci-dessous. Sub FillList(ByRef lstBox As ListBox, strQry As String) 'fill combo with value list from recordset 'to be used when recordset is too slow to requery for sorting Dim rs As Recordset, strSrc As String, i As Integer Set rs = CurrentDb.OpenRecordset(strQry, dbOpenSnapshot) lstBox.RowSourceType = "Value list" lstBox.ColumnCount = rs.Fields.Count ReDim arSrc(rs.RecordCount * rs.Fields.Count) Do Until rs.EOF For i = 0 To rs.Fields.Count - 1 strSrc = strSrc & rs.Fields(i) & ";" Next i rs.MoveNext Loop lstBox.RowSource = Left(strSrc, Len(strSrc) - 1) End Sub