Bruk av Variabler

I dette avsnittet finner du grunnleggende informasjon om bruk av variabler i LibreOffice Basic.

Navgivingskonvensjoner for variabelnavn

Et variabelnavn kan inneholde maksimalt 256 tegn. Det fÞrste tegnet i et variabelnavn mÄ vÊre en bokstav i det engelske alfabetet A-Z eller a-z. De andre tegnene kan vÊre en bokstav, et tall eller understrek («_»). Ingen andre tegn er tilatt. LibreOffice Basic skiller ikke mellom store og smÄ bokstavar i variabelnavnene. Et variabelnavn kan ogsÄ inneholde mellomrom, men mÄ da skrives mellom hakeparenteser.

Eksempel pÄ variabelnavn:


      MyNumber=5

Rett


      MyNumber5=15

Rett


      MyNumber_5=20

Rett


      My Number=20

Ugyldig. Variabelnavn med mellomrom mÄ skrives mellom hakeparenteser


      [My Number]=12

Rett


      DéjàVu=25

Ikke gyldig, spesialtegn ikke tillatt


      5MyNumber=12

Ikke gyldig, variabel kan ikke starte med et tall


      Number,Mine=12

Ikke gyldig, punktum er ikke tillatt


Definere Variabler

I LibreOffice Basic trenger du ikke Ă„ spesifikt deklarere variabler. En variabeldeklarasjon can utfĂžres medDim uttrykket. Du kan deklarere mer enn en variabel samtidig , gjennom Ă„ separere de med kommategn. For Ă„ definere variabeltypen, bruk enten en type-dekalrasjon etter navnet, eller et passende nĂžkkelord.

Eksempler for variabeldeklarasjoner:


      Dim a$

Deklarerer variablen som en streng


      Dim a As String

Deklarerer variabelen som en streng


      Dim a$, b As Integer

Deklarerer en variabel som Stren og en som heltall


      Dim c As Boolean

Deklarerer c som en boolsk (logisk) variabel som kan vĂŠre SANN eller FALSK


Det er veldig viktig at du bruker type- deklarasjon tegn nÄr du deklarerer variabler, selv om brukt i deklarasjonen istedenfor et nÞkkelord. Derfor er fÞlgene uttrykk ugyldige.


      Dim a$

Deklarerer "a" som en Streng


      a="TestString"

Typedeklarasjonen mangler "a$="


Advarselsikon

NÄr du har deklarert en variabel som en spesifik type, kan du ikke deklarere samme variabelnavn med en annen type


Tving Variabeldeklarasjoner

For tvingende deklarasjon av variabler, bruk fĂžlgende kommando:


Option Explicit

Uttrykket Option Explicit mÄ vÊre pÄ den fÞrste linjen i modulen, foran den fÞrste SUB-prosedyren. Normalt skal bare tabeller («array») deklarerest spesielt. Alle andre variablar blir deklarerte med typedeklarasjonstegnet eller, dersom dette er slÞyfet, som standardtypen Single.

Variabeltyper

LibreOffice Basic har stĂžtte for fire variabelklasser:

Heltallsvariabler

Integervariabler varierer fra -32768 til 32767. Hvis du tilordner en flytende punktverdi til en heltallvariabel, avrundes desimaltallene til neste heltall. Heltallvariabler beregnes raskt i prosedyrer og passer for tellervariabler i slĂžyfer. En heltallvariabel krever bare to bytes minne. "%" er tegndeklarasjonskarakteren.


Dim Variable%
Dim Variable As Integer

Variabeltypen Long

Long integer-variabler varierer fra -2147483648 til 2147483647. Hvis du tilordner en flytende punktverdi til en lang heltallvariabel, avrundes desimaltallene til neste heltall. Long integervariabler beregnes raskt i prosedyrer og er egnet for tellervariabler i slĂžyfer for store verdier. En lang integervariabel krever fire byte minne. "&" er typedeklarasjonskarakteren.


Dim Variable&
Dim Variable As Long

Desimalvariabler

Decimale variabler kan ta positive eller negative tall eller null. NĂžyaktigheten er opptil 29 siffer.

Du kan bruke pluss (+) eller minus (-) tegn som prefiks for desimaltall (med eller uten mellomrom).

Hvis et desimaltall er tilordnet en heltallvariabel, rundes LibreOffice Basic om figuren opp eller ned.

Bruk av Variabler

Enkeltvariabler kan ta positive eller negative verdier som spenner fra 3.402823 x 10E38 til 1.401298 x 10E-45. Enkeltvariabler er flytende punktvariabler, hvor desimalpresisjonen minker ettersom ikke-desimaldelen av tallet Þker. Enkeltvariabler er egnet for matematiske beregninger av gjennomsnittlig presisjon. Beregninger krever mer tid enn for heltallsvariabler, men er raskere enn beregninger med dobbelvariabler. En enkelt variabel krever 4 byte minne. Typeklarings karakteren er "!".


Dim Variable!
Dim Variable As Single

Bruk av Variabler

Dobbeltvariabler kan ta positive eller negative verdier som spenner fra 1.79769313486232 x 10E308 til 4.94065645841247 x 10E-324. Dobbelvariabler er flytende punktvariabler, der desimalnÞyaktigheten reduseres ettersom ikke-desimaldelen av tallet Þker. Dobbelvariabler er egnet for presise beregninger. Beregninger krever mer tid enn for enkle variabler. En dobbel variabel krever 8 byte minne. Typeklarings karakteren er "#".


Dim Variable#
Dim Variable As Double

Valutavariablene

Valutavariabler lagres internt som 64-biters tall (8 byte) og vises som et fast desimalsummer med 15 ikke-desimalt og 4 desimaler. Verdiene varierer fra -922337203685477.5808 til +922337203685477.5807. Valutavariabler brukes til Ă„ beregne valutaverdier med hĂžy presisjon. Typeklarasjons karakteren er "@".


Dim Variable@
Dim Variable As Currency

Bruk av Variabler

Strengvariabler kan inneholde tegnstrenger med opptil 65.535 tegn. Hver karakter lagres som den tilsvarende Unicode-verdien. Strengvariabler er egnet for tekstbehandlingen innenfor programmer og for midlertidig lagring av alle ikke-skrivbare tegn opp til maksimal lengde pÄ 64 Kbytes. Minnet som kreves for lagring av strengvariabler avhenger av antall tegn i variabelen. Typeklarings karakteren er "$".


Dim Variable$
Dim Variable As String

Bolske variabler (av type Boolean)

Logiske variabler kan inneholde en av to verdier: SANN (TRUE) og USANN (FALSE). Talelt 0 representerer USANN, alle andre verdier gir SANN.


Dim Variable As Boolean

Bruk av Variabler

Datovariabler kan kun inneholde verdier for datoer og klokkeslett. Verdiene lagres i et internt format. Verdier som er tilordnet datovariabler med Dateserial, Datevalue, Timeserial eller Timevalue blir automatisk konverterte til det interne formatet. Datovariablene kan konverteres til vanlige tall med funksjonene Dag, MĂ„ned, År eller Time, Minutt, Sekund. Det interne datoformatet brukes for Ă„ regne ut forskjellen mellom to datoer og/eller klokkeslett. Datovariablene kan kun deklareres med nĂžkkelordet Date.


Dim Variable As Date

Initiale variabelverdier

NÄr en variabel blir deklarert, vil verdien automatisk bli satt til null. Merk likevel:

Numeriske variabler fÄr automatisk verdien «0» nÄr de blir deklarerte.

Datovariabler fĂ„r den interne verdien 0 som tilsvarer konvertering av "0" med funksjonene Dag, MĂ„ned og År eller Time, Minutt og Sekund.

Strengvariabler fÄr verdien av en tom streng ("") nÄr de blir deklarerte.

Array (tabeller)

LibreOffice Basic kan gjenkjenne en- eller flerdimensjonal arrays, definert av en spesifisert variabeltype. Arrays er egnet for redigering av lister og tabeller i programmer. Individuelle elementer i en matrise kan adresseres gjennom en numerisk indeks.

Array mÄ defineres med uttrykket Dim. Det finst flere mÄter Ä definere indeksomrÄdet for en tabell pÄ:


      Dim Text$(20)

21 element nummererte fra 0 til 20


      Dim Text$(5,4)

30 elementer (en matrise med 6 x 5 element)


      Dim Text$(5 To 25)

21 elementer nummererte fra 5 til 25


      Dim Text$(-15 To 5)

21 elementer (inklusiv 0) nummerert fra -15 til 5


IndeksomrÄdet kan inneholde bÄde positive og negative tall.

Konstanter

Konstantene har en fast verdi. De kan defineres kun en gang i programmet og verdien kan ikke endres senere.


Const ConstName=Expression