Möchte man die Anzahl Dimensionen eines Arrays in VB ermitteln, sucht man hier vergebens nach einer entsprechenden Funktion. Mittels der allseits bekannten UBound-Funktion lässt sich lediglich die Größe einer einzelnen Array-Dimensionen ermitteln (Anzahl Elemente der Dimension). Wie schon so oft hilft uns hier wieder einmal nur das Windows-API aus der Klemme. Nachfolgende Funktion ermittelt die Anzahl Dimensionen des übergebenen Arrays und gibt diese entsprechend zurück. Für nicht initialisierte Arrays, d.h. Arrays die keinerlei Dimension enthalten, gibt die Funktion 0 zurück. Option Explicit ' benötigte API-Deklaration Private Declare Sub CopyMemory Lib "kernel32" _ Alias "RtlMoveMemory" ( _ Destination As Any, _ Source As Any, _ ByVal Length As Long) Public Function GetArrayDim(ByRef vArray As Variant) As Integer ' Handelt es sich überhaupt um ein Array? Dim DimCount As Integer DimCount = -1 If IsArray(vArray) Then Dim vPtr As Long DimCount = 0 vPtr = VarPtr(vArray) + 8 CopyMemory vPtr, ByVal vPtr, 4 CopyMemory vPtr, ByVal vPtr, 4 If vPtr Then CopyMemory DimCount, ByVal vPtr, 2 End If GetArrayDim = DimCount End Function Beispiele: ' Arrays in verschiedenen Dimensionen erstellen Dim array1(10) As String Dim array2(10, 5) As Long Dim array3(2 To 8, 1 To 6, 3 To 9) As Byte Dim array4() As Variant ' Dimensionen ermitteln Debug.Print GetArrayDim(array1) ' gibt 1 zurück Debug.Print GetArrayDim(array2) ' gibt 2 zurück Debug.Print GetArrayDim(array3) ' gibt 3 zurück Debug.Print GetArrayDim(array4) ' gibt 0 zurück Dieser Tipp wurde bereits 16.253 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
Neu! sevEingabe 3.0 Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |