XOPPSLAG() Litt avansert bruk, og hva i all verden er EgR()??

|

XOPPSLAG() erstatter funksjonen FINN.RAD(), og er vesentlig råere i bruk. Her skal vi se hvordan vi kan bruke matrisefunksjonalitet i XOPPSLAG() – altså få formelen til å spre resultatet over flere rader, og også litt på mitt lille hjertebarn EgR() som refererer til siste skrevne rad i en kolonne – og fyller et hull i Excel for meg.

OBS. Hjertebarnet EgR() har jeg sluttet å bruke etter at TRIMMEOMRÅDE() ble introdusert i Excel (Microsoft Office 365). Se artikkelen Hvor euforisk kan man bli av et punktum?

XOPPSLAG() finner du i Microsoft365, ikke i Office 16/19

Les også: Aldri mer FINN.RAD(). Nå er det XOPPSLAG() som gjelder
Les også: XOPPSLAG() med flere søkekriterier – dette er utklassing!

Lenke til eksempelfilen finner du nederst i artikkelen

(Artikkelen fortsetter under videoruten. )
YouTube player

Formelen i B2

Formelen i B2 er den mest alminnelige bruken av XOPPSLAG:

=XOPPSLAG(A2;Årslønn!$C:$C;Årslønn!$D:$D;"-";0)

Den søker etter verdien i A2 (som i dette tilfellet er 1) i kolonne C i fanen Årslønn og returner verdien i kolonne D hvis den finner verdien. Finnes ikke verdien, returneres «-«.

Formelen i C2

Denne formelen er spenstigere ved at den angir hvilke rader nedover formelresultatet skal spre seg over.

=XOPPSLAG(A2:A11;Årslønn!$C:$C;Årslønn!$A:$A;"-";0)

Her ser du at A2 i B2-formelen er utvidet til A2:A11. Dette gjør at formelen automatisk settes inn på radene C2 til C11. Bare pass på at cellene under C2 er tomme, ellers vil du få feilmeldingen #Overflyt:

Formelen i D2

Her erstatter vi A2:A11 med funksjonen INDIREKTE(«A2:A» & H2).

XOPPSLAG

INDIREKTE() leser innholdet fra en tekst, og vil i dette returnere verdien i radene A2:A100. Fordelen med dette er at hvis alle formlene i kolonne B-F er skrevet på denne måten, kan vi utvide området formelen sprer seg over ved å endre antallet i H2.

=XOPPSLAG(INDIREKTE("A2:A" & H2);Adresse!$A:$A;Adresse!$B:$B;"Ikke funnet";0)

Formelen i E2 (og forsåvidt F2)

Det ultimate ville jo være om formelen selv kunne finne ut hva som er siste rad i kolonnen hvor søkeverdien står, i dette tilfellet A-kolonnen. Excel har ikke noen slik funksjon, så jeg har skrevet en som heter EgR() – ExcelGuruRader – som gjør akkurat dette.

XOPPSLAG

Her kan jeg sette 1000 eller 100000 i H2, men formelresultatet vil ikke spre seg lenger ned enn til siste rad med innhold i A-kolonnen.

=XOPPSLAG(EgR(A2;H2);Adresse!$A:$A;Adresse!$C:$C;"Ikke funnet";0)

Hvorfor ha med H2 med antall rader som skal undersøkes? Det har med hastighet å gjøre. Hvis jeg skulle sjekke alle radene i kolonnen, er det 1 048 576 rader. Bruker jeg funksjonen i fem kolonner, blir det 5 242 880 rader å sjekke, og det tar tid. Hvis det holder å sjekke 500 rader, er det gjort på et blunk.

EgR()??

Dette er en funksjon du enkelt kan ta med deg i dine egne Excelbøker. Kopier Celle J2 fra eksempelboka og lim inn i din egen Excelbok. Da kopieres EgR() automatisk inn, og er klar til bruk.

EgR()!

EgR() er en LAMBDA-funksjon, og du finner den under Formler->Navnbehandling

XOPPSLAG

EgR() Formelen

For de mest interesserte:

= LAMBDA(
    TableStart;
    CheckRows;
    LET(
      FirstColumn;
      TEXTBEFORE(TEXTAFTER(CELL("address"; TableStart); "$"); "$");
      FirstRow;
      CELL("row";TableStart);
      CheckRows1;
      CheckRows;
      Rng;
      FirstColumn & "1:" & FirstColumn & CheckRows1;
      INDIRECT(  FirstColumn
               & FirstRow
               & ":"
               & FirstColumn
               & MAX(ROW(INDIRECT(Rng)) * NOT(ISBLANK(INDIRECT(Rng)))))))(A2; H2)

Last ned Excelboka her: XOppslag-Matrise-rev10.xlsx (31 downloads )

Similar Posts