Im Beitrag “Fehlerbehandlung per VBA hinzufügen” (www.access-im-unternehmen.de/1514) zeigen wir, wie man Fehlerinformationen direkt per VBA in eine Fehlertabelle schreibt, um diese später zu kontrollieren. Wenn man nun als Entwickler eine fehlerhafte Datei mit einigen protokollierten Fehlern vom Benutzer erhält, möchte man vielleicht direkt die fehlerhaften Stellen einsehen. Dazu muss man allerdings erst nachsehen, welches Modul, welche Prozedur und welche Zeile betroffen sind, dann die entsprechende Stelle im VBA-Editor suchen und so weiter. Bei einer umfangreichen Datenbank kann das sehr mühselig werden, vor allem wenn man sich von Fehler zu Fehler hangelt. Deshalb liefern wir in diesem Beitrag noch eine praktische Ergänzung, wenn Sie ohnehin schon eine Tabelle wie aus dem oben genannten Beitrag zum Speichern der Fehler verwenden: Ein Formular, dass diese Fehler anzeigt und mit dem Sie per Mausklick auf einen Fehler direkt die entsprechende Stelle im VBA-Editor anzeigen können.
Ziel des Beitrags
Ziel dieses Beitrags ist es, die Inhalte der Tabelle aus Bild 1 in einem Unterformular in der Datenblattansicht anzuzeigen, um diese dann zu selektieren und die Stelle zu der Fehlermeldung direkt im Quellcode anzuzeigen.
Bild 1: Die Inhalte dieser Tabelle sollen im Formular angezeigt werden
Formular und Unterformular erstellen
Dazu legen wir zunächst ein Unterformular an, dem wir als Datensatzquelle die Tabelle tblErrors zuweisen. Wir ziehen alle Felder dieser Tabelle bis auf das Feld ID in den Detailbereich des Formularentwurfs und stellen die Eigenschaft Standardansicht auf Datenblatt ein.
Dann schließen wir das Formular und speichern es unter dem Namen sfmErrors. Anschließend legen wir das Hauptformular an. Diesem fügen wir das Unterformular sfmErrors per Drag and Drop aus dem Navigationsbereich hinzu. Damit es seine Größe anpasst, wenn wir die Größe des Formulars ändern, stellen wir die beiden Eigenschaften Horizontaler Anker und Vertikaler Anker auf den Wert Beide ein. Die beiden automatisch geänderten entsprechenden Eigenschaften des Bezeichnungsfeldes stellen wir wieder auf die ursprünglichen Werte Links und Oben ein.
Außerdem stellen wir die Eigenschaften Datensatzmarkierer, Navigationsschaltflächen, Trennlinien und Bildlaufleisten für das Hauptformular auf Nein ein.
Schließlich benötigen wir zumindest eine Schaltfläche, mit der wir den aktuell markierten Fehler im VBA-Editor anzeigen können. Dieser geben wir den Namen cmdShowInVBAEditor und hinterlegen dann eine Ereignisprozedur für das Ereignis Beim Klicken.
Anschließend sieht das Formular in der Entwurfsansicht wie in Bild 2 aus.
Bild 2: Das Formular frmErrors mit Unterformular
Verweis zum Programmieren des VBA-Editors
Bevor wir diese füllen, fügen wir, sofern noch nicht vorhanden, noch einen Verweis auf die Bibliothek Microsoft Visual Basic Extensibility 5.3 Object Library hinzu. Diese liefert das Objektmodell, mit dem wir den VBA-Editor programmieren können.
Prozedur zum Anzeigen und Markieren einer Zeile
Anschließend füllen wir die Ereignisprozedur cmdShowInVBAEditor_Click mit der Prozedur aus Listing 1.
Private Sub cmdErrors_Click() Dim objVBProject As VBIDE.VBProject Dim objVBComponent As VBIDE.VBComponent Dim objCodeModule As VBIDE.CodeModule Dim objCodePane As VBIDE.CodePane Dim strErrorModule As String Dim strErrorProcedure As String Dim lngErrorLine As String Dim lngLine As Long Dim lngLastLine As Long Dim strLine As String Dim strProcedure As String Dim intProcType As vbext_ProcKind With Me!sfmErrors.Form strErrorModule = !ErrorModule strErrorProcedure = !Errorprocedure lngErrorLine = !ErrorLine End With Set objVBProject = VBE.ActiveVBProject Set objVBComponent = objVBProject.VBComponents(strErrorModule) Set objCodeModule = objVBComponent.CodeModule For lngLine = 1 To objCodeModule.CountOfLines strLine = objCodeModule.Lines(lngLine, 1) Debug.Print lngLine, Val(strLine), strLine strProcedure = objCodeModule.ProcOfLine(lngLine, intProcType) If strProcedure = strErrorProcedure And lngErrorLine = Val(strLine) Then Exit For End If Next lngLine Set objCodePane = objCodeModule.CodePane lngLastLine = lngLine Do While right(Trim(objCodeModule.Lines(lngLastLine, 1)), 1) = "_" lngLastLine = lngLastLine + 1 Loop objCodePane.SetSelection lngLine, 1, lngLastLine, 999 objCodePane.Show End Sub
Listing 1: Prozedur zum Anzeigen des Codes zu einer Fehlermeldung
Ende des frei verfügbaren Teil. Wenn Du mehr lesen möchtest, hole Dir ...
den kompletten Artikel im PDF-Format mit Beispieldatenbank
diesen und alle anderen Artikel mit dem Jahresabo