Accéder au contenu principal

Articles

Affichage des articles du 2010

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

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

Re-lier les tables Access

Function RelinkTables() Dim td As TableDef, db As Database Dim strFolder As String , arTmp As Variant , strBe As String Set db = CurrentDb strFolder = Left(db.Name, InStrRev(db.Name, "\" , , vbTextCompare)) For Each td In db.TableDefs If Left(td.Connect, 9) = ";DATABASE" Then 'linked ? If Not fValidTable(td.Name) Then 'bad ? arTmp = Split(td.Connect, "\" ) td.Connect = ";DATABASE=" & strFolder & arTmp(UBound(arTmp)) td.RefreshLink End If End If Next td End Function Function fValidTable(TableName As String ) As Boolean Dim lCount As Long On Error Resume Next lCount = DFirst( "1" , TableName) fValidTable = (Err.Number = 0) End Function

Disques différentiels avec Virtualbox

En matière de virtualisation, les disques différentiels sont une solution très pratique, mais je n'ai découvert que récemment que cette solution était aussi disponible dans Virtualbox. Pour ceux qui ne connaissent pas le principe des disques différentiels, prenons l'exemple suivant: un formateur a besoin pour ses formations de Windows 7 avec différentes versions d'Office (2003, 2007, 2010) et ceci en différentes langues. Soit il crée 6 machines virtuelles (mv) de 10 GB chacune, ce qui occuperait 60 GB sur son laptop tout en ne lui laissant que d'assez petits disques virtuels (dv), soit il utilisera des disques différentiels: un disque de base avec Windows 7 (disque dit "immuable") une machine virtuelle par version/langue. Chaque VM utilisera le disque de base, et Virtualbox créera automatiquement un disque "différentiel" où il n'enregistrera que les différences avec le disque de base (soit la taille de l'installation d'Office). Dans ...

Agrandir un disque virtuel Virtualbox

Après avoir créé un disque Virtualbox et y avoir installé Windows 7 pour une présentation, je me suis rendu compte que l'espace disponible était insuffisant pour installer les autres programmes dont j'avais besoin. Après pas mal de recherches et des essais de diverses solutions plus ou moins efficaces et compliquées, j'ai fini par trouver la solution ici . Pour résumer: arrêtez la machine virtuelle (VM) et libérez le disque dur trop petit (oldhd.vdi) créez un nouveau disque virtuel via le gestionnaire de médias (appelons le newhd.vdi) copiez le contenu du disque trop petit (oldhd.vdi) dans le nouveau disque ainsi créé: VBoxManage clonehd --existing oldhd.vdi newhd.vdi Cette opération peut être assez longue. montez le nouveau disque newhd.vdi comme disque de la machine virtuelle enfin modifiez la taille de la partition pour qu'elle occupe tout son nouvel espace disponible. Pour W7, il suffit de démarrer la VM, et d'utiliser le gestionnaire de disque de Window...

Lister le contenu d'une base Access

Cette requete toute simple permet d'affichier tous les objets d'une base: SELECT s.Name AS Table_Name, nz([Connect],"") & nz([database],"") AS Db, IIf([s].[ForeignName]<>[name],[s].[foreignname]) AS ForeignName, s.DateCreate, s.DateUpdate, Switch([type]=1,"tbl",[type]=4,"sql",[type]=5,"qry",[type]=6,"lnk",[type]=-32761,"mod",[type]=-32764,"rpt",[type]=-32768,"frm") AS ObjType, s.Type FROM MSysObjects AS s WHERE (((s.Type) In (1,4,5,6,-32761,-32764,-32768)) AND ((Left([Name],1))<>"~") AND ((Left([Name],4))<>"MSys")) ORDER BY s.Type, s.Name;