Avatar billede contici Nybegynder
23. marts 2011 - 14:21 Der er 5 kommentarer og
1 løsning

Excel genberegner VBA funktion, HVER gang der ændres i en vilkårlig celle

Jeg har et Excel dokument med VBA funktion jeg selv har lavet. Dokumentet har flere faner, hvor kun to af dem benytter VBA funktionen.

Hvis jeg går ind i et vilkårligt ark i en vilkårlig celle og skriver et eller andet, så genberegner de to ark som benytter VBA funktionen. Cellen der ændres, er IKKE input celle til VBA funktionen. Jeg forstår simpelthen ikke hvad der sker.

Jeg ved jeg kan sætte Excel til kun at genberegne når jeg beder den om det, men det er ikke løsningen for mig, og yderligere har jeg stødt på dette problem før, og ville meget gerne have et svar på hvad der går galt.

Håber nogen kan hjælpe.
Avatar billede Slettet bruger
23. marts 2011 - 14:35 #1
Hvorfor overhovedet bruge en VBA-funktion. Kan det ikke klares med en formel?
Avatar billede Ialocin Novice
23. marts 2011 - 14:56 #2
Hej contici

Hvilken hændelser/event ligger din VBA kode i ??
Med andre ord, hvad kalder din kode ?

Med venlig hilsen, Nicolai
Avatar billede contici Nybegynder
23. marts 2011 - 16:26 #3
Hej igen,

Det kan ikke klares med formler.

Jeg har imidlertidigt fundet ud af problemet.

Jeg har nemlig brugt INDIREKTE() funktionen i Excel filen. Det gør at hver gang jeg ændrer en vilkårlig celle, som ingen andre celler refererer til, så re-beregner den hele skidtet (om den kun re-beregner VBA kode, og ikke excel formler ved jeg ikke).

Jeg ved ikke om der er nogen idé med dette fra MS's side, eller om det er en fejl.

Løsningen blev at jeg ikke bruger INDIREKTE() mere, men bruger INDEKS() istedet. Nu kører det hele som det skal.

Selvom problemet er løst, ville det være sjovt at høre om nogen ved hvorfor Excel re-beregner når der bruges INDIREKTE() funktionen?
Avatar billede Slettet bruger
23. marts 2011 - 17:25 #4
Volatile Functions
A volatile function is always recalculated at each recalculation even if it does not appear to have any changed precedents. Using many volatile functions slows down each recalculation, but it makes no difference to a full calculation. You can make a user-defined function volatile by including Application.Volatile in the function code.

Some of the built-in functions in Excel are obviously volatile: RAND(), NOW(), TODAY(). Others are less obviously volatile: OFFSET(), CELL(), INDIRECT(), INFO().

Du kan læse mere her:
http://msdn.microsoft.com/en-us/library/aa730921(v=office.12).aspx?ppud=4#Office2007excelPerf_UnderstandingCalculationMethodsExcel
Avatar billede contici Nybegynder
17. oktober 2011 - 09:36 #5
dkhanknu laver du svar, så får du point
Avatar billede Slettet bruger
17. oktober 2011 - 09:48 #6
OK.
Hans
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Excel kurser for alle niveauer og behov – find det kursus, der passer til dig

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester