Hem Sociala medier Arbetar med VBA-funktioner som returnerar en array i Excel 2016 - dummies

Arbetar med VBA-funktioner som returnerar en array i Excel 2016 - dummies

Innehållsförteckning:

Video: LETARAD med Excel 2025

Video: LETARAD med Excel 2025
Anonim

Array formler är en av Excel mest kraftfulla funktioner. Om du är bekant med matrisformler kan du vara glad att veta att du kan skapa VBA-funktioner som returnerar en matris.

Återkommer en rad månadsnamn

Låt oss börja med ett enkelt exempel. Funktionen MonthNames returnerar en 12-elements array av - du gissade det - månadens namn.

Funktion Månadnamn () MonthNames = Array ("Januari", "Februari", "Mars", "April", "Maj", "Juni", "Juli", "Augusti", "September" Oktober "," november "," december ") Avsluta funktionen

För att använda MonthNames-funktionen i ett arbetsblad måste du ange det som en 12-cells arrayformel. Välj till exempel område A2: L2 och skriv in = MonthNames () . Tryck sedan på Ctrl + Shift + Enter för att mata in matrisformeln i alla 12 valda celler. Kolla in resultatet.

Använd funktionen MonthNames för att returnera en 12-elementars array.

Om du vill att månadsnamnen ska visas i en kolumn markerar du 12 celler i en kolumn och använder denna arrayformel. (Glöm inte att skriva in den genom att trycka på Ctrl + Shift + Enter.)

= TRANSPOSE (MonthNames ())

Du kan också välja en enda månad från matrisen. Här är en formel (inte en matrisformel) som visar det fjärde elementet i matrisen: april.

= INDEX (MonthNames (), 4)

Återgå en sorterad lista

Anta att du har en lista med namn som du vill visa i sorterad ordning i ett annat cellområde. Skulle det inte vara trevligt att ha ett kalkylblad fungerar det för dig?

Den här anpassade funktionen gör just det: Det tar en cell med ett kolumn som sitt argument och returnerar sedan en rad av de sorterade cellerna. Område A2: A13 innehåller några namn. Område C2: C13 innehåller denna multicell array-formel. (Kom ihåg att du måste ange formeln genom att trycka på Ctrl + Shift + Enter.)

Använda en anpassad funktion för att returnera ett sorterat område.
= Sorterad (A2: A13)

Här är koden för Sorterad funktion:

Funktion Sorterad (Rng Som Räckvidd) Dim SortedData () Som Variant Dim Cell Som Range Dim Temp Som Variant, j Så länge Dim NonEmpty As Long 'Överför data till SortedData för varje cell i Rng Om inte IsEmpty (Cell) Då NonEmpty = NonEmpty + 1 ReDim Bevara SortedData (1 Till NonEmpty) SortedData (NonEmpty) = Cell. Värde Slut om nästa cell "Sortera arrayen För i = 1 Till NonEmpty För j = i + 1 Till NonEmpty Om SorteradData (i)> SorteradData (j) Då Temp = SorteradData (j) SorteradData (j) = SorteradData (i) SorteradData (i) = Temp slutet om nästa j Nästa jag "Överför arrayen och returnera den Sorterad = Application.Transpose (SortedData) Slutfunktion

Funktionen Sorterad startar genom att skapa en array med namnet SortedData. Denna array innehåller alla nonblank-värdena i argumentområdet. Därefter sorteras sorteringsdatabasen med en bubbelsortalgoritm. Eftersom matrisen är en horisontell matris måste den transponeras innan den returneras av funktionen.

Den sorterade funktionen fungerar med en rad av vilken storlek som helst, så länge den ligger i en enda kolumn eller rad. Om de osorterade uppgifterna är i rad måste din formel använda Excels TRANSPOSE-funktion för att visa de sorterade dataen horisontellt. Till exempel:

= TRANSPOSE (Sorterad (A16: L16))
Arbetar med VBA-funktioner som returnerar en array i Excel 2016 - dummies

Redaktörens val

Vad är en Java-karta? - dummies

Vad är en Java-karta? - dummies

Arrays och specialiserade listor gör det möjligt att utföra en fantastisk uppsättning uppgifter med Java. Det finns dock situationer där en Java-applikation behöver något som är mer relaterat till en databas, utan att egentligen ha allt databasbagage (som att behöva köpa en separat applikation). Till exempel kanske du vill kunna ...

Några få saker om Java Math - dummies

Några få saker om Java Math - dummies

Tro det eller inte, datorer - även de mest kraftfulla - Ha vissa begränsningar när det gäller att utföra matematiska beräkningar. Dessa begränsningar är vanligtvis obetydliga, men ibland slår de sig och biter på dig. Här är de saker du behöver se upp för när du gör matte i Java. Helhetsflöde Det grundläggande problemet ...

Vad är recursion i Java Programmering? - dummies

Vad är recursion i Java Programmering? - dummies

Rekursion är en grundläggande programmeringsteknik som du kan använda i Java, där en metod kallar sig för att lösa ett problem. En metod som använder denna teknik är rekursiv. Många programmeringsproblem kan lösas endast genom rekursion, och vissa problem som kan lösas med andra tekniker löses bättre genom rekursion. En av ...

Redaktörens val

4 Måste-inkludera i din blogg sidobardesign - dummies

4 Måste-inkludera i din blogg sidobardesign - dummies

Din bloggens sidofält är viktig fastighet som bör innehålla de element du vill ha mest. När du utformar din blogg sidofält kan du dra från en nästan oändlig lista över sidospårelement. Genom att välja noggrant vad som ska inkluderas (och vad som inte ska inkluderas) kan du ställa in din blogg från andra.

5 Användbara Wordpress Plugins - dummies

5 Användbara Wordpress Plugins - dummies

Om du bloggar på en självhävd plattform med WordPress-programvara, är det dags att anpassa din blogg med plug-ins - programvara som kan "anslutas" till din befintliga WordPress bloggprogramvara. Plug-ins gör det möjligt för dig att göra allt från funktionsbildspel i dina blogginlägg för att ansluta sociala medier till din webbplats. Här är fem användbara ...

7 Sätt att erövra Writer's Block som en Blogger - dummies

7 Sätt att erövra Writer's Block som en Blogger - dummies

Varje bloggare möter författarens block i ett tid eller annan. Om du är den typ av bloggare som sköter innehåll varje dag, kan författarens block vara stäverande. Kan du inte ta en paus för att få ditt skrivande mojo tillbaka? Prova en (eller flera) av dessa sju sätt att slå författarens block för att få dig tillbaka ...

Redaktörens val

10 Stora elektronikkomponentkällor - dummies

10 Stora elektronikkomponentkällor - dummies

Letar du efter några bra källor till dina elektroniska delar? Denna lista ger dig några fleråriga favoriter, både inom och utanför Nordamerika. Denna lista är inte uttömmande. Du hittar bokstavligen tusentals specialutbud för ny och begagnad elektronik. Plus, Amazon och eBay ger virtuella marknadsplatser för alla sorters säljare - ...

Elektronik Basics: Resistance - dummies

Elektronik Basics: Resistance - dummies

I elektronikvärlden är motståndet inte meningslöst. Faktum är att motstånd kan vara mycket användbart. Utan motstånd skulle elektronik inte vara möjligt. Elektronik handlar om att manipulera strömmen av ström, och ett av de mest grundläggande sätten att manipulera strömmen är att minska det genom resistans. Utan motstånd strömmar strömmen oreglerad och där ...

Digital elektronik: Så här installerar du BASIC Stamp Editor och Anslut till Stämpeldummorna

Digital elektronik: Så här installerar du BASIC Stamp Editor och Anslut till Stämpeldummorna

För att berätta för BASIC Stamp vad du vill göra i ditt digitala elektronikprojekt måste du programmera det. BASIC Stamp Windows Editor är den programvara som du använder på din dator för att skapa program som kan laddas ner till en BASIC Stamp-mikrokontroller. Denna programvara är tillgänglig gratis från Parallax webbplats. ...