Innehållsförteckning:
Video: You Bet Your Life: Secret Word - Tree / Milk / Spoon / Sky 2024
De flesta programmeringsspråk stöder arrays, inklusive VBA. En array är en grupp av variabler som delar ett namn. Du hänvisar till en viss variabel i arrayen med hjälp av matrisnamnet och ett indexnummer inom parentes. Du kan till exempel definiera en grupp med 12 strängvariabler för att hålla namnen på årets månader. Om du heter arrayen MonthNames kan du referera till det första elementet i arrayen som MonthNames (1), det andra elementet som MonthNames (2) och så vidare.
Declaration arrays
Innan du kan använda en array, måste du måste förklara det. Inga undantag. Till skillnad från normala variabler är VBA mycket strikt om denna regel. Du deklarerar en array med en dim eller offentlig uppgift, precis som du förklarar en vanlig variabel. Men du måste också ange antalet element i arrayen. Du gör detta genom att ange det första indexnumret, sökordet till och det sista indexnumret - alla inom parentes. Följande exempel visar hur man deklarerar en grupp med 100 heltal:
Dim MyArray (1 till 100) Som heltal
När du deklarerar en array kan du välja att bara ange det övre indexet. Om du släpper bort det lägre indexet antar VBA att det är 0. Därför förklarar båda följande påståenden samma 101-elementars array:
Dim MyArray (0 till 100) Som Integer Dim MyArray (100) Som heltal
Om du vill att VBA antar att 1 (i stället för 0) är det lägre indexet för dina arrayer, ta med följande påstående i avsnittet Deklarationer högst upp på din modul:
Alternativ Bas 1
Detta uttalande tvingar VBA att använda 1 som det första indexnumret för arrays som endast anger det övre indexet. Om detta uttalande är närvarande är följande uttalanden identiska, båda deklarerar en 100-elementars array:
Dim MyArray (1 till 100) Som Integer Dim MyArray (100) Som Integer
Multidimensionella Arrays
De arrays skapade i de tidigare exemplen är alla endimensionella arrays. Tänk på endimensionella arrays som en enda rad av värden. Arrayer du skapar i VBA kan ha så många som 60 dimensioner - även om du sällan behöver mer än två eller tre dimensioner i en array. Följande exempel deklarerar en 81-heltalsmatris med två dimensioner:
Dim MyArray (1 till 9, 1 till 9) Som heltal
Du kan tänka på denna matris som upptar en 9 x 9-matris - perfekt för att lagra alla siffror i ett Sudoku-pussel.
För att hänvisa till ett specifikt element i denna array måste du ange två indexnummer (liknar dess "rad" och dess "kolumn" i matrisen).Följande exempel visar hur du kan tilldela ett värde till ett element i denna array:
MyArray (3, 4) = 125
Detta uttalande tilldelar ett värde till ett enskilt element i matrisen. Om du tänker på matrisen i form av en 9 x 9-matris, tilldelar detta 125 till elementet som ligger i den tredje raden och den fjärde kolumnen i matrisen.
Så här förklarar du en tredimensionell array med 1 000 element:
Dim My3DArray (1 till 10, 1 till 10, 1 till 10) Som heltal
Du kan tänka på en tredimensionell array som en kub. Att visualisera en array med mer än tre dimensioner är svårare.
Dynamiska arrayer
Du kan också skapa dynamiska arrayer. En dynamisk array har inte ett förinställt antal element. Förklara en dynamisk grupp med en tom uppsättning parenteser:
Dim MyArray () Som heltal
Innan du kan använda denna array måste du använda ReDim-förklaringen för att berätta för VBA hur många element matrisen har. Vanligtvis bestäms antalet element i matrisen medan koden körs. Du kan använda ReDim-satsen ett antal gånger, ändra arrayens storlek så ofta som behövs. Följande exempel visar hur man ändrar antalet element i en dynamisk grupp. Det förutsätter att NumElements-variabeln innehåller ett värde som din kod beräknat.
ReDim MyArray (1 till NumElements)
När du redimensionerar en array med ReDim, torkar du bort alla värden som för tillfället lagras i matriselementen. Du kan undvika att förstöra de gamla värdena med hjälp av Preserve-sökordet. I följande exempel visas hur du kan behålla en arrays värden när du redimensionerar arrayen:
ReDim Preserve MyArray (1 till NumElements)
Om MyArray för närvarande har tio element och utför det föregående uttalandet med NumElements som motsvarar 12, De första tio elementen förblir intakta och arrayen har plats för ytterligare två element (upp till numret i variabelnumret). Om NumElements är lika med 7 behålls de första sju elementen, men de återstående tre elementen uppfyller deras nedgång.