Oprettet ons. d. 06. august 2003 kl. 12:50:39

ferdinand.k
ferdinand.k (26.663 point. Point ude: 105)

optimering af funktion

hejsa... i forlængelse af spg: http://www.eksperten.dk/ (...) kunne jeg godt tænke mig at høre om der var en der kunne optimere denne funktion yderligere. Det er en funktion der bruges ofte, og skal derfor køre så hurtigt som muligt... Dertil skal der siges at jeg bruger ikke "helligdag" tabellen/funktionen til noget...

Skrevet ons. d. 06. august 2003 kl. 12:56:47| #1

ferdinand.k
ferdinand.k (26.663 point)
kommer lige her for god ordens skyld:

Public Function Arbejdsdag(Dato As Date) As Boolean
    If Weekday(Dato) = 7 Or Weekday(Dato) = 1 Then
        Arbejdsdag = False
    ElseIf DCount("*", "Helligdage", "Dato = #" & Format(Dato, "yyyy-mm-dd") & "#") > 0 Then
        Arbejdsdag = False
    Else
        Arbejdsdag = True
    End If
End Function

Public Function FindAntalArbejdsdage(Startdato As Date, Slutdato As Date) As Long
    Dim tmpDato As Date
    Dim n As Integer
    tmpDato = Startdato
    Do Until tmpDato >= Slutdato
        If Arbejdsdag(tmpDato) Then
            n = n + 1
        End If
        tmpDato = tmpDato + 1
    Loop
    FindAntalArbejdsdage = n
End Function

Skrevet ons. d. 06. august 2003 kl. 16:39:27| #2

staticdata
staticdata (14.989 point)
Afhængig af gnst. afstand mellem datoerne: Hvis den er høj, kan du jo udnytte, at hver 7. dag er lørdag og/eller søndag. Så er det ikke nødvendigt at spørge på alle datoer. Hvis der typisk er giga-mange datoer, kan du tælle hvor mange dage der er ialt, og derfra fratrække antallet af lørdage og søndage, samt antallet af helligdage...Koden må du selv fedte med, synes jeg.

Skrevet ons. d. 06. august 2003 kl. 21:22:39| #3

terry
terry (244.612 point)
Public Function Arbejdsdag(Dato As Date) As Boolean
    If Weekday(Dato) = 7 Or Weekday(Dato) = 1 Then
        Arbejdsdag = False
    else
        Arbejdsdag = True
    End If
End Function

Public Function FindAntalArbejdsdage(Startdato As Date, Slutdato As Date) As Long
    Dim tmpDato As Date
    Dim n As Integer
    tmpDato = Startdato
    Do Until tmpDato >= Slutdato
        If Arbejdsdag(tmpDato) Then
            n = n + 1
        End If
        tmpDato = tmpDato + 1
    Loop
    FindAntalArbejdsdage = n
End Function

Skrevet tor. d. 07. august 2003 kl. 07:21:21| #4

ferdinand.k
ferdinand.k (26.663 point)
det man bruger funktionen til, er at søge efter hvormange arbejdsdage der er mellem d. 15 i denne, og d. 14 i næst-kommende måned. så det er jo ikke et gigastort tal... :)

Skrevet tor. d. 07. august 2003 kl. 09:15:09| #5

terry
terry (244.612 point)
ferdinand.k> You said that you are not using  "Helligedage" table! I have removed it from the loop but as far as I see it you MUST go through each day to see if it is a working day or a weekend (saturday or sunday). I would also have thought that holidays (Easter etc.) would need to be taken into concideration too!

Skrevet tor. d. 07. august 2003 kl. 09:21:36| #6

ferdinand.k
ferdinand.k (26.663 point)
det er ikke nødvendigt med helligdage... jeg skal sådan set kun have antallet af hverdage ud mellem to datoer, oftest med en måneds mellemrum...

Skrevet tor. d. 07. august 2003 kl. 11:01:45| #7

pecl
pecl (16.655 point)
Hej Ferdinand K.
Se Terrys svar her
http://www.eksperten.dk/ (...)

Skrevet tor. d. 07. august 2003 kl. 15:53:52| #8

terry
terry (244.612 point)
Hi Pecl>Gald you can find what I made, I never seem to be able to :o)
Even so there isnt a great difference in either method.

Skrevet tor. d. 07. august 2003 kl. 18:00:24| #9

staticdata
staticdata (14.989 point)
Hvis du ikke synes, at ANTAL.ARBEJDSDAGE er god nok, og hvis ALDRIG medregner helligdage og du ALTID skal beregne fra 15 dennes til 14 næstes, vil jeg påstå at du må kunne udnytte at hver 7.dag er lørdag eller søndag...Der vil altid være 28-31 dage ialt, herunder 4-5 lørdage/søndage - take that, hvis du altså er ude på ekstrem sub-optimering!

Skrevet tor. d. 07. august 2003 kl. 20:26:01| #10

staticdata
staticdata (14.989 point)
En grim, nogle vil sige kinky, variant af 'Arbejdsdag' er iøvrigt:
Public Function Arbejdsdag(Dato As Date) As Boolean
Arbejsdag = Weekday(Dato) <> 7 And Weekday(Dato) <> 1
End Function

Jeg kan ikke lige gennemskue, om du kunne optimere mere ved at lave en
..
Dim a as integer
a=Weekday(dato)
Arbejsdag = a <> 7 And a <> 1
..
herved sparer du jo et kald af Weekday...men det må du næsten selv teste.

Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Link til et dokument

Oprettet den 10. februar 2012 kl. 14.15
omn giver 60 point for svar | Giv et svar »

Formular med flere paramtre

Oprettet den 9. februar 2012 kl. 16.48
stuegnu giver 100 point for svar | Giv et svar »

Kodemodul ???

Oprettet den 8. februar 2012 kl. 17.05
olejohn giver 200 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger