Hem Sociala medier Arbetar med Arrays för VBA-programmering i Excel 2016 - dummies

Arbetar med Arrays för VBA-programmering i Excel 2016 - dummies

Innehållsförteckning:

Video: You Bet Your Life: Secret Word - Tree / Milk / Spoon / Sky 2024

Video: You Bet Your Life: Secret Word - Tree / Milk / Spoon / Sky 2024
Anonim

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.

Arbetar med Arrays för VBA-programmering i Excel 2016 - dummies

Redaktörens val

Hur man ändrar bakgrunds- och textfärger i Dreamweaver - dummies

Hur man ändrar bakgrunds- och textfärger i Dreamweaver - dummies

I Dreamweaver, du kan ändra bakgrunden och de textfärger som finns tillgängliga i kategorin Utseende. Observera att CSS-alternativen rekommenderas via HTML-alternativ. När du använder alternativen Utseende (CSS) skapar Dreamweaver motsvarande stilar för kroppstaggen automatiskt. När du använder några CSS-alternativ i dialogrutan Sidegenskaper, Dreamweaver ...

Redaktörens val

Hur du formaterar text i Word 2007 - dummies

Hur du formaterar text i Word 2007 - dummies

Word 2007 låter dig formatera text antingen medan du skriver eller efter att du har skrivit. Med den första tekniken väljer du först ett textformateringskommando och skriver sedan texten. All text du skriver är formaterad som vald. För mer komplex formatering är det bättre att skriva texten först, gå tillbaka, markera ...

Hur man formaterar ett bord i Word 2010 - dummies

Hur man formaterar ett bord i Word 2010 - dummies

För att formatera ett bord i Word 2010 en rad, justera bredden på ett tabellelement - du kan använda Words tabeller Tabellverktyg efter att bordet har skapats. Tabellerna Tabellverktyg visas bara när en tabell redigeras eller markeras. Och den bästa tiden att formatera och ...

Hur du formaterar text med Word 2007 Format Painter - dummies

Hur du formaterar text med Word 2007 Format Painter - dummies

Du kan använda Word 2007 Formatera Painter för att snabbt kopiera tecken och styckeformatering från en bit text till en annan. Formatfärgen fungerar bara om du redan har lite text formaterad som du vill. Du kan använda formateraren för att formatera en sektion eller flera sektioner av text. Till ...

Redaktörens val

Skala din SketchUp-modell tills fotot ser rätt ut - dummies

Skala din SketchUp-modell tills fotot ser rätt ut - dummies

När du är nöjd med vägen Din textur sträcker sig för att passa ett ansikte i din SketchUp-modell, en av två saker kommer att vara sanna: proportionerna är korrekta. Bilden ser inte utsträckt eller squashed. Detta är bara fallet om ansiktet som du använde fotokonsttexten redan var exakt på ...

SketchUp Pro 2014s nya klassificeringsverktyg - dummies

SketchUp Pro 2014s nya klassificeringsverktyg - dummies

SketchUp Pro 2014 introducerade ett nytt verktyg som heter Classifier. Om du använder Pro kan du märka grupper och komponenter (som nu kollektivt kallas objekt) med information om vad de är. När du delar din modell med personer som använder sofistikerade BIM-modeller (Building Information Modeling), kan de lättare integrera det ...

Storlekar Mater När 3D-utskrift SketchUp-modeller

Storlekar Mater När 3D-utskrift SketchUp-modeller

Har alla 3D-skrivare en minimal och maximal storlek på objektet kan bygga. Dessa storlekar bestäms vanligtvis av storleken på verktyget som skriver ut materialet och av den totala storleken på skrivaren. Att bygga något större måste du bli kreativ. För att bygga något mindre behöver du en dyrare 3D ...