Excel VBA

Hurtig respons.
Får en til at tænke selvstændigt.
Hjælpsom.

Ole Cordes Kristensen, Ce-Tec

Excel VBA

Det er rart at kunne tage kurset i sit eget tempo, når det lige passer ind, men det giver også en risiko for at det lige bliver langstrækt nok, men så er det godt underviseren kan holde én lidt i ørerne med mails wink

Eva Bonne Alkærsig, EBA InterrimControlling

Excel VBA

Hurtig response på opgaver.

Udfordrende opgaver.

Flemming Pedersen, Semco Maritime

Excel VBA

Det har været rart at man selv kan bestemme tempoet og hvornår man laver opgaverne. Man kan også få hjælp til at få løst opgaverne anderledes, samt få hjælp til andre opgaver. Jeg synes også det har været sjovt at man ikke får det hele serveret, men skal søge lidt information selv.

Laila Jensen, Statens Serum Institut

Excel VBA

Tak for et rigtigt godt og lærerigt kursus.

En af de store fordele ved kurset er, at man kan tage det i det tempo man ønsker og der er ikke noget tidspres.

Opgaverne er gode og udfordrene. Man kan selv, indenfor rammerne, bestemme hvor meget man vil gøre ud af det.

Beskrivelserne til opgaverne er lavet på en sådan måde, at der er også overladt lidt til ens egen fantasi, som jeg synes er en meget god ting.

Kurset har et rigtigt godt niveau, og materialet er godt lavet.

Underviseren ??? Ja, jeg ved ikke hvornår han sover.

Der går ikke lang tid efter man har sendt en opgave, til den er rettet, og altid med en god og konstruktiv kommentar. Også man får underviserens løsningsforslag.

Der er altid hurtig og god hjælp at hente, hvis man er gået i stå. Man får ikke bare løsningen, men et hint, så man kan komme videre.

Jeg vil varmt anbefale det til andre, og gør det !

Endnu engang tak for et godt kursus.

Med venlig hilsen

Peter Juul Jacobsen

Peter Juul Jacobsen, Mærsk Olie & Gas A/S

< >
Se flere referencer

Simpel brugerdialog

Der er to interessante metoder til at skabe lidt dialog med brugeren.

MsgBox

Den første hedder MsgBox og bruges, som navnet antyder, til at vise en beskedboks på skærmen. Syntaksen for MsgBox er (hentet fra hjælpe funktionen):

MsgBox prompt[, buttons] [, title] [, helpfile, context]

Dette betyder at man skal angive en prompt, men de ting, der står i kantede parenteser behøver man ikke angive. Det betyder at vi f.eks. kan skrive

MsgBox "Velkommen til min makro"

Og det kommer så til at se sådan her ud:

Excel VBA kursus - brug af msgbox- fjernundervisning

Og skriver man

MsgBox "Velkommen til min makro", vbYesNo, "Min makro"

Kommer det til at se sådan her ud:

Excel VBA kursus - brug af msgbox med titel og knapper - fjernundervisning

Bemærk, at når man kommer til MsgBox "Velkommen til min makro", dukker der en liste op over mulige knapper man kan sætte på sin MsgBox. vbYesNo dækker i virkeligheden over tallet 4! - det er én af mange konstanter, der er indbygget i VBA.

Returværdi fra en MsgBox

Det giver jo ikke meget mening at sætte knapper på sådan en MsgBox, hvis vi ikke kan finde ud af, hvilken af de to knapper brugeren har trykket på. Vil man have resultater ud af en MsgBox ser det sådan her ud:

svar = MsgBox("Velkommen til min makro", vbYesNo, "Min makro") 
Range("A1").Value = svar

Bemærk, at der er kommet parenteser på! - det er sådan vi signalerer, at vi gerne vil have et svar retur fra metoden. svar er "bare" en variabel, der bruges til at gemme værdien der kommer retur fra MsgBoxen - man bestemmer selv hvad sådanne variable skal hedde.

Knapper på msgbox'en

I eksemplet ovenfor kan du se, at vi kan sætte ja/nej knapper på msgbox'en, men vi har flere muligheder!

Prøv at skrive.

MsgBox "Velkommen til min makro", vbYesNo + vbExclamation + vbDefaultButton2, "Min makro"

Bemærk, at der er også er ændret på, hvilken knap, der er default. Du har følgende knapper at vælge imellem:

 

Konstant Betydning
vbOKOnly Viser OK alene
vbOKCancel Viser OK og Cancel.
vbAbortRetryIgnore Viser Abort, Retry, og Ignore
vbYesNoCancel Viser Yes, No, og Cancel
vbYesNo Viser Yes og No
vbRetryCancel Viser Retry og Cancel
vbCritical Viser Critical Message ikon.
vbQuestion Viser Warning Query ikon.
vbExclamation Viser Warning Message ikon.
vbInformation Viser Information Message ikon.
vbDefaultButton1 Første knap er default.
vbDefaultButton2 Anden knap er default.
vbDefaultButton3 Tredje knap er default.
vbDefaultButton4 Fjerde knap er default.
vbApplicationModal Brugeren skal klikke på knappen før der kan arbejdes videre i Excel.
vbSystemModal Brugeren skal klikke på knappen før der kan arbejdes videre på computeren
vbMsgBoxHelpButton Tilføjer en hjælp-knap
VbMsgBoxSetForeground Sætter msgbox'en til at være det forreste vindue
vbMsgBoxRight Teksten er højrestillet
vbMsgBoxRtlReading Angiver at teksten skal skrives fra højre mod venstre

InputBox

En InputBox giver brugeren mulighed for at skrive lidt til os. Syntaksen er:

InputBox(prompt[, title] [, default] [, xpos] [, ypos] [, helpfile, context])

Og skriver man

svar = InputBox("Hvad hedder du? ", "Velkommen til") 
Range("A1").Value = svar

Ser det sådan her ud:

Excel VBA kursus - brug af inputbox - fjernundervisning

Bemærk, at der her altid skal være parenteser - det er jo ikke specielt smart at lave en inputbox, hvis man ikke bruger resultatet til noget.

Avanceret brugerdialog

Vil man gerne lave en mere avanceret brugerdialog skal man bruge en Userform - det skal vi lære om senere.

Når du har betalt for kurset får du adgang til øvelser til hver lektion. Og når du har fået godkendt din besvarelse får du desuden adgang til mine løsningsforslag med ekstra tips og trix.