Programmeren in VB&VBA
Wat is VB? VB is de afkorting voor Visual Basic. Dit is een programmeertaal ontworpen door Microsoft om een alternatief te bieden voor VC++. Deze taal laat toe (in tegenstelling tot VC++) om relatief makkelijk Windows Forms te creëren.
Wat is VBA? VBA staat voor Visual Basic for Applications. Dit omdat deze ontworpen is speciaal om makkelijk in MS Word, Access of Excel een programma te schrijven op eenvoudige wijze. De taal die hiervoor gekozen werd was Visual Basic, maar laat toe om makkelijk de inhoud van deze soort files te wijzigen.
' het reserveren van geheugenruimte wordt gedaan met het type Dim.
' In dit geval reserveren we 4 keer een type string
' en 1 keer een type integer.
Dim lab1 As String
Dim lab2 As String
Dim lab3 As String
Dim lab4 As String
Dim a As Integer
' Dit is de Next Button. We verhogen de teller en maken dan gebruik
' van de specifieke functies van VBA voor excel namelijk Range.
' Dit specificeert welk veld of van welk veld tot welk veld. Hieronder maken
' we de keuze om van de oorspronkelijke rij een offset met a te nemen
' en geen tov de kolom. Deze Value (waarde: string, getal, ..) vullen we in
' in de labels
Private Sub CommandButton1_Click()
a = a + 1
Label1.Caption = Range(lab1).Offset(a, 0).Value
Label2.Caption = Range(lab2).Offset(a, 0).Value
Label3.Caption = Range(lab3).Offset(a, 0).Value
Label4.Caption = Range(lab4).Offset(a, 0).Value
End Sub
' Dit is de Previous Button. We verlagen de teller en maken dan gebruik
' van de specifieke functies van VBA voor excel namelijk Range.
' Dit specificeert welk veld of van welk veld tot welk veld. Hieronder maken
' we de keuze om van de oorspronkelijke rij een offset met a te nemen
' en geen tov de kolom. Deze Value (waarde: string, getal, ..) vullen we in
' in de labels
Private Sub CommandButton2_Click()
a = a - 1
Label1.Caption = Range(lab1).Offset(a, 0).Value
Label2.Caption = Range(lab2).Offset(a, 0).Value
Label3.Caption = Range(lab3).Offset(a, 0).Value
Label4.Caption = Range(lab4).Offset(a, 0).Value
End Sub
' een lege toets
Private Sub CommandButton3_Click()
End Sub
' Deze functie wordt aangeroepen wanneer de form opstart, men kan ook nog
' andere kiezen nl: wanneer er op geklikt word,...
' we stellen de teller in op 0 en geven de velden een beginwaarde.
Private Sub UserForm_Activate()
a = 0
lab1 = "A1"
lab2 = "B1"
lab3 = "C1"
lab4 = "D1"
Label1.Caption = Range(lab1).Value
Label2.Caption = Range(lab2).Value
Label3.Caption = Range(lab3).Value
Label4.Caption = Range(lab4).Value
End Sub
Woordenlijst
Het kan handig zijn allerlei codes van Visual Basic te verzamelen. Deze lijst kan namelijk een belangrijke steun zijn bij het programmeren. Hieronder een woordenlijst met codes in Visual Basic. U wordt vriendelijk uitgenodigd codes toe te voegen.
Algemene simpele opdrachten
- Sub hier titel() : titel van de macro (komt helemaal bovenaan)
- Selection.TypeText Text:="(de tekst)" : op de plaats van de cursor komt de tekst
- ActiveDocument.Paragraphs.Count : regels tellen
- ActiveCell.Value : inhoud actieve cel wordt uitgelezen (Excel)
- ActiveDocument.Save : opslaan
- ActiveDocument.PrintOut Copies:=(getal) : een aantal keer afdrukken
- ActiveDocument.Printout Range:=wdPrintCurrentPage : uitsluitend huidige pagina printen (range betekent afdrukbereik)
- ActiveDocument.Range(0, 20).Select : eerste 20 tekens van open document worden geselecteerd (0, 20 te vervangen door ieder gewenst getal)
- Documents.Save : alle geopende documenten worden opgeslagen
- Documents(1).Save : eerste document in verzameling wordt opgeslagen (1 te vervangen door ieder gewenst getal, zo slaat 2 het tweede document op)
- Documents.Add : nieuw document
- End Sub : einde van de macro
- formuliernaam.Show : formulier wordt getoond
- Range("A1:A5").Formula = "woord" : cellen A1 tot en met A5 worden met een bepaald woord gevuld (Excel, A1:A5 te vervangen door ieder gewenste cel)
- Selection.Copy : selectie wordt in het Microsoft klembord opgeslagen
- Sheets.PrintOut : alle bladen in werkmap worden afgedrukt (Excel)
- Selection.TypeText : tekst in nieuw document plaatsen
- Selection.TypeParagraph : nieuwe alinea wordt begonnen
- Workbooks.Add : nieuwe werkmap (Excel)
VBA constanten
- vbCrLf : regelterugloop en regelinvoer
- vbCr : regelterugloop
- vbLf : regelinvoer
- vbNewLine : automatisch één van bovenstaande, afhankelijk van het besturingssysteem
- vbTab : Tab-teken
VBA functies
- LCase(tekenreeks) : tekst omzetten naar kleine letters
- UCase(tekenreeks) : tekst omzetten naar hoofdletters
- Left(tekenreeks, x) : de eerste x tekens aan de linkerkant van de tekenreeks
- Right(tekenreeks, x) : de eerste x tekens aan de rechterkant van de tekenreeks
- Mid(tekenreeks, x, y) : een tekenreeks beginnend bij karakter x ter lengte van y uit de grotere tekenreeks
- variabele = Inputbox(vraag, titel, ...) : invoer vragen aan de gebruiker
- MsgBox(melding, knoppen, titel, ...) : een melding op het scherm tonen
- Len() : lengte van tekenreeks achterhalen
Operatoren
Algemene operatoren
- = : gelijk aan
- <> : ongelijk aan
- < : kleiner dan
- > : groter dan
- <= : kleiner dan of gelijk aan
- => : groter dan of gelijk aan
Getal operatoren
- + : optellen
- - : aftrekken
- * : vermenigvuldigen
- / : delen
- ^ : machtsverheffen
- ^0.5 : makkelijke manier om vierkantwortels te trekken
Logische operatoren
- Not : uitkomst vergelijking omdraaien
- And : twee of meer vergelijkingen in 1 If instructie beoordelen
- Or : beoordelen of 1 van de vergelijkingen waar is
- Xor : is true wanneer 1 van de uitdrukkingen true is, maar niet beide, dan is het false.
Tekst operatoren
- & of + : om twee strings te te verbinden (! er wordt geen spatie tussen gezet !)
Gegevenstypes
Elke variabele kan je definiëren aan de hand van Dim 'naamveriabele' as 'gegevenstype' (je kan ook Private ... as ... gebruiken: dit heeft dezelfde betekenis als dim: je kan de variabele enkel in deze module gebruiken of je kan Public ... as ... gebruiken: je kan de variabele in elke module gebruiken); als je ingewikkelde programma's schrijft is het handig om bovenaan je code (voor Sub ()) option explicit toe te voegen, dit betekent dat je alle variabelen moet definiëren en is handig om geen typfouten te maken. Nadat je je variabele dan hebt gedefiniëerd kan je deze gelijkstellen aan een waarde. Hier een tabel met soorten gegevenstypes (deze tabel is niet zeker niet compleet, maar biedt een handige basis).
Gegevenstype | Verklaring |
---|---|
string | bevat tekst, altijd gelijkstellen aan iets tussen dubbele aanhalingstekens |
boolean | bevat een juist of fout-waarde, handig voor logische variabelen, altijd gelijkstellen aan True of False |
integer | bevat een getal tussen 32768 en zijn negatieve equivalent, enkel gehele getallen (dus geen komma's), gebruikt 2 bytes geheugen |
long | bevat een getal tussen 2147483648 en zijn negatieve equivalent, enkel gehele getallen (dus geen komma's), gebruikt 4 bytes geheugen |
byte | bevat een getal tussen 0 en 255, enkel gehele getallen (dus geen komma's), gebruikt logischerwijs 1 byte geheugen |
single | bevat een kommagetal, gebruikt 4 bytes geheugen en kan dus evengrote getallen aan als een long |
double | bevat een kommagetal, gebruikt 8 bytes geheugen en kan dus ongeveer dubbel zoveel cijfers verwerken als een single |
currency | bevat een kommagetal, is SUPERnauwkeurig maar verbruikt SUPERveel geheugen |
variant | bevat ofwel een tekst, ofwel een getal, of meer specifieke andere toestanden (die niet echt voor beginners zijn weggelegd) |
vbMsgBoxResult | bevat de uitkomst van de knoppen van een msgbox, vb. als er op ok is gedrukt kan je schrijven If vbmsgboxresult = vbok then ...) |
Object | bijna alle objecten (zoals info over je computer, geluiden, ...) worden hierin opgeslagen, ook eerder niet voor beginners |
date | hierin kan je info over data opslaan, je kan er ook tijden in opslaan |
Een veelgemaakte fout is dat er een verkeerd gegevenstype wordt gebruikt voor een functie (vb. je stelt een stringvariabele gelijk aan een functie die een getal als uitkomst geeft), voor het juiste gegevenstype te achterhalen kan je in office-applicaties de functie selecteren en dan op F1 drukken voor het help-menu te openen. In dit help-menu staat zo goed als altijd vermeld wat het verwachte gegevenstype is.
Beslissingsinstructies en logische operatoren
If ... Then
De If ... Then instructie bestaat standaard uit drie delen:
het If- deel: hierachter volgt een stelling (zoals variabele < 1, zie onderdeel operatoren voor meer soorten stellingen),
het Then-deel: hierachter komt altijd een nieuwe regel met wat er moet gebeuren als de stelling waar is,
het End If-deel: het End If-deel is nodig om duidelijk te maken dat de If ... Then instructie is afgelopen.
Optionele delen van de If ... Then instructie
Optionele delen zijn delen die niet altijd nodig zijn maar wel handig kunnen zijn om te gebruiken.
Het Else-deel: direct hierachter komt wat er moet gebeuren als de stelling niet waar is, als je deze instructie niet hebt wordt er niks gedaan als de stelling niet waar is.
Het ElseIf-deel: direct hierachter volgt een nieuwe stelling, je koppelt dus eigenlijk twee dingen aan elkaar Else + If en na deze nieuwe voorwaarde komt een nieuwe lijn waarop dan weer de code wordt getypt wat er moet gebeuren als die stelling waar is.
voorbeeld If...Then instructie
Sub test()
Dim variabele as string
variabele = inputbox ("geef je tekst in")
If variabele = "Hallo" Or "hallo" then
msgbox "ook hallo"
ElseIf variabele = "Gegroet" then
msgbox "wie zegt dat nu nog?"
Else
msgbox "geen groet?"
end If
End Sub
IIf
De IIf instructie heeft dezelfde betekenis als If ... Then ... Else maar dan op één regel.
Je geeft het als volgt in: IIf(stelling, waar deel, vals deel)
voorbeeld IIf instructie
Sub test ()
Dim variabele as vbmsgboxresult
variabele = msgbox ("klik op een knop", vbokcancel, "knop")
Iif (variabele = vbOk, msgbox "je klikte op OK", msgbox "je klikte op cancel")
End Sub
Select Case ...
De select Case ... instructie bestaat standaard uit minstens 3 delen:
het Select Case-deel: hierachter volgt de naam van de variabele waar je stellingen aan gaat koppelen,
het Case-deel: hierachter schrijf je een waarde (vb. Case 4 wilt zeggen: in het geval dat de variabele 4 is) en dan op een nieuwe regel de code die dan moet gebeuren, je kan zoveel Case-delen in 1 Select Case ... instructie zetten als je wilt,
het End Select-deel: zelfde functie als End If-deel bij de If ... then instructie.
Optionele delen van de Select Case ... instructie
het Case Else-deel: dit schrijf je als laatste case en het is letterlijk in het geval dat het iets anders is dan al vermeld, zelfde functie als het Else-deel bij de If ... Then instructie
voorbeeld van de Select Case ... instructie
Sub test()
dim variabele as string
variabele = inputbox ("geef een getal tussen 1 en 4 in")
select case variabele
case 1
msgbox "één"
Case 2
msgbox "twee"
case 3
msgbox "drie"
case 4
msgbox "vier"
case else
msgbox "foutieve invoer: het getal lag niet tussen de 1 en de 4!", vbcritical + vbokonly
End
End Select
End Sub
Lussen
Het eerste deel van een lus staat altijd op voor de lus en het tweede deel erachter en de voorwaarde komt bij de V (de V moet je dus vervangen door een stelling)
- For V ... Next : herhaalt een groep instructies een vast aantal keren
vb. voor V: i = 1 to 10
- For Each V ... Next : herhaalt een groep instructies voor elk element in een verzameling
- Do ... Loop : herhaalt en groep instructies tot een voorwaarde waar is
- Do While V ... Loop : herhaalt instructies zolang voorwaarde aan begin waar is
vb. voor V: i > 10
- Do ... Loop While V : herhaalt instructies zolang voorwaarde aan einde waar is
- Do Until V... Loop : voert instructies uit tot voorwaarde aan begin waar is
- Do ... Loop Until V : voert instructies uit tot voorwaarde aan einde waar is
- For V ... Next ... Step : herhaal een vast aantal malen
- While V ... Wend : herhaal zolang
Methoden
- .Show : formulier wordt op scherm getoond
- .Hide : formulier wordt onzichtbaar
- AddItem(...) : voegt ... toe, waardoor deze tekst onder het vorige komt te staan
- Clear : maakt het scherm leeg
Instructies
- Private : variabelen declareren (buiten een macro, enkel voor die module)
- Public : variabelen declareren (voor alle module's, buiten een macro)
- Dim : variabelen declareren (liefst bovenaan in de macro)
- ReDim : éénmaal gedimensioneerd array wijzigen
- ReDim Preserve : bestaand array herdimensioneren zonder inhoud te verliezen
Diversen
- Step : tellervariabele in grotere stappen laten ophogen
- CInt(...) : zet de inhoud van ... om in integer
- Str(...) : zet ... om in String