Sunday, October 2, 2016

Excel vba bewegende gemiddelde kode

Bewegende gemiddelde Hierdie voorbeeld leer jy hoe om die bewegende gemiddelde van 'n tydreeks in Excel te bereken. 'N bewegende avearge gebruik te stryk onreëlmatighede (pieke en dale) om maklik tendense herken. 1. In die eerste plek kan 'n blik op ons tyd reeks. 2. Klik op die blad Data, kliek Data-analise. Nota: cant vind die Data-analise knoppie Klik hier om die analise ToolPak add-in te laai. 3. Kies bewegende gemiddelde en klik op OK. 4. Klik op die insette Range boks en kies die reeks B2: M2. 5. Klik op die boks interval en tik 6. 6. Klik in die uitset Range boks en kies sel B3. 8. Teken 'n grafiek van hierdie waardes. Verduideliking: omdat ons die interval stel om 6, die bewegende gemiddelde is die gemiddeld van die vorige 5 datapunte en die huidige data punt. As gevolg hiervan, is pieke en dale stryk uit. Die grafiek toon 'n toenemende tendens. Excel kan nie bereken die bewegende gemiddelde vir die eerste 5 datapunte, want daar is nie genoeg vorige datapunte. 9. Herhaal stappe 2 tot 8 vir interval 2 en interval 4. Gevolgtrekking: Hoe groter die interval, hoe meer die pieke en dale is glad nie. Hoe kleiner die interval, hoe nader die bewegende gemiddeldes is om die werklike data punte. Hou jy van hierdie gratis webwerf Deel asseblief hierdie bladsy op GoogleRolling Gemiddeld tabel sal ons kyk na 'n program in Excel VBA dat 'n rollende gemiddelde tafel skep. Plaas 'n opdrag knoppie op jou werkblad en voeg die die volgende kode reël: Range (quotB3quot).Value WorksheetFunction. RandBetween (0, 100) Hierdie kode lyn gaan 'n ewekansige getal tussen 0 en 100 in sel B3. Ons wil Excel VBA om die nuwe voorraad waarde te neem en plaas dit op die eerste posisie van die rollende gemiddelde tafel. Alle ander waardes moet afbeweeg een plek en die laaste waarde moet verwyder word. Skep 'n Werkkaart Verandering gebeurtenis. Kode by die Werkblad Verandering Event sal uitgevoer word deur Excel VBA wanneer jy 'n sel te verander op 'n werkblad. 2. Klik op Sheet1 (Sheet1) in die projek Explorer. 3. Kies Werkvel uit die drop-down list links. Kies Verandering van die reg drop-down list. Voeg die volgende kode lyne om die Werkblad Verandering Event: 4. Verklaar 'n veranderlike genoem newvalue van tipe Integer en twee reekse (firstfourvalues ​​en lastfourvalues). Dowwe newvalue As Integer. firstfourvalues ​​Soos Range, lastfourvalues ​​Soos Range 5. Die Werkkaart Verandering Event luister na al die veranderinge op Sheet1. Ons wil net Excel VBA om iets te doen as iets verander in sel B3. Om dit te bereik, voeg die volgende kode reël: As Target. Address quotB3quot Toe 6. Ons inisialiseer newvalue met die waarde van sel B3, firstfourvalues ​​met Range (quotD3: D6quot) en lastfourvalues ​​met Range (quotD4: D7quot). newvalue Range (quotB3quot).Value Stel firstfourvalues ​​Range (quotD3: D6quot) Stel lastfourvalues ​​Range (quotD4: D7quot) 7. Nou kom die eenvoudige truuk. Ons wil hê dat die rollende gemiddelde tafel te werk. Jy kan dit doen deur die vervanging van die afgelope vier waardes met die eerste vier waardes van die tafel en die plasing van die nuwe voorraad waarde by die eerste posisie. lastfourvalues. Value firstfourvalues. Value Range (quotD3quot).Value newvalue 8. Moenie vergeet om die as verklaring af te sluit. 9. Ten slotte, gee die formule GEMIDDELDE (D3: D7) in sel D8. 10. Toets die program deur te kliek op die opdrag button. I wil 'n bewegende gemiddelde van die laaste bereken, sê 20, getalle van 'n kolom. 'N Probleem is dat sommige van die selle van die kolom leeg kan wees, moet hulle geïgnoreer word nie. Voorbeeld: 'n bewegende gemiddelde van die afgelope drie sou wees (155167201) / 3. Ive het probeer om dit met behulp van die gemiddelde, neutraliseer, indeks implementeer, maar ek eenvoudig nie weet hoe. Im 'n bietjie bekend is met makros, sodat so 'n oplossing sal werk boete: MovingAverage (A13) Dankie vir enige wenke of oplossings gevra 12 Maart 11 by 15:36 Gee dit met controlshiftenter om dit 'n skikking formule te maak. Dit sal die jongste drie waardes vind. As jy wil meer of minder, verander die twee gevalle van 3 in die formule om alles wat jy wil. Hierdie deel gee die 4 hoogste ry getal van al die selle wat 'n waarde, of 5 in jou voorbeeld gevolg rye 6, 8 en 9 is die 1ste deur 3 hoogste rye met 'n waarde. Hierdie deel terugkeer 9 TRUEs of FALSEs gebaseer op die vraag of die ry getal is groter as die 4 grootste. Dit vermeerder die waardes in A1: A9 deur diegene 9 TRUEs of FALSEs. TRUEs word omgeskakel na 1 en FALSEs aan nul. Dit laat 'n som funksie soos hierdie, want al die waardes bo 155 hoef te bevredig die ry aantal kriteria, die kry vermenigvuldig met nul. Ek het 'n kort script in VBA geskryf. Hopefull dit doen wat jy wil. Hier jy: 1) Ek het perk gestel aan 360 selle. Dit beteken dat die script nie sal kyk vir meer as 360 selle. As jy wil om dit te verander dan verander die aanvanklike waarde van die toonbank. 2) Die script terugkeer nie afgeronde gemiddelde. Verander die laaste ry om MovingAverage Ronde (CDbl (TMP / i), 2) 3) Die gebruik daarvan is net soos jy wil, so tik MovingAverage (A13) in die sel. Enige kommentaar welcome. Moving Gemiddeld in VBA bewegende gemiddelde in VBA Hi. Ive is op soek oral MrExcel en die res van die web, maar in al die post oor VBA-kode vir bewegende gemiddeldes presies is nie 'n oplossing vir wat ek wil doen. Im werk met 'n baie groot hoeveelhede data. Oor 10 jaar van die daaglikse voorraad opbrengste, en doen 10 aandele op 'n slag (dis oor 20k datapunte) en ek nodig het om 'n 10, 50, of 100 dae - bewegende gemiddelde vir elke voorraaditem bereken op elke dag. Ek weet hoe om dit te doen in 'n gereelde formule, maar dis stadig, en is ook geneig om die gebruiker fout sedert 1 gemis beroerte jaar van bewegende gemiddeldes kan afgooi. Na ongeveer 3 dae van die werk, het ek gevind dat 'n oplossing te vind wat werk, maar is manier om meer stadig as voorheen Hier is die kode wat Im werk met nou. Verdof Ek Soos Long Dim LastRow As Long LastRow Range (B amp Rows. Count).end (xlUp).Row l selle (1, W).Value As l 0 Toe MsgBox Tik Range in C1 GoTo Lastline anders vir IL Om LastRow - 2 Range (N amp i 2).FormulaR1C1 GEMIDDELDE (RC-12: R - amp l - 1 amp C-12) Volgende i-reeks (N2: N5000).Select Selection. Copy Selection. PasteSpecial Plak: xlPasteValues ​​Selection. NumberFormat. 00 Application. CutCopyMode Vals Einde As tweede Range kolom (O3: o5000).Clear Vir IL Om LastRow - 2 Range (o amp i 2).FormulaR1C1 GEMIDDELDE (RC-12: R - amp l - 1 amp C-12) Volgende Ek omvang (O2: o5000).Select Selection. Copy Selection. PasteSpecial Plak: xlPasteValues ​​Selection. NumberFormat 0,00 Application. CutCopyMode Vals. tweede kolom herhaal 8 keer gaan kolom W Lastline: End Sub Dit werk baie goed, uit elke lyn begin by sê 10 datapunte in (vir 'n 10 dag bewegende gemiddelde) Dit vul in die kode tien dae terug te gaan op 'n slag . Dan wanneer dit bereik die ou end is dit kopieer en plak die waardes van die kolom sodat die formule nie die geval is moet aktief herbereken van toe af. Die probleem wat ek gevind het is dat gaan volgende af die lys vir 2000 dae is ondraaglik. Ek het probeer om oefensessie n Application. WorksheetFunction. Average, maar ek kon nie kry die reeks nie gedefinieer word as die kolomme X aantal dae bo-aan elke lyn. Kan iemand helpHere is 'n kode wat nuttig vir diegene wat met behulp tegniese ontleding in die handel moet wees en wil strategieë te toets in Excel. Dit bere die eenvoudige, lineêr geweeg en eksponensiële bewegende gemiddelde. Verdere sal Ek aan te bied en te verduidelik die stappe vir die skep van die vorm en die VBA-kode. Voeg 'n UserForm 8211 Naam: MAForm Voeg vier etikette van die Gereedskap Beheer 8211-onderskrifte soos per bogenoemde print screen Voeg 'n ComboBox vir die bewegende gemiddelde tipe seleksie. Dit is vernoem comboTypeMA Voeg twee RefEdit kontroles vir die insette reeks en die uitset reeks. Voeg 'n teksboks vir selecing die bewegende gemiddelde tydperk Voeg twee knoppies: Naam: buttonSubmit, Onderskrif: Stuur en Naam: buttonCancel, Onderskrif: Die styl Ten einde die drop-down list vir MA tipe seleksie genereer en laai die gebruiker vorm, 'n nuwe module sal plaas met die onderstaande kode. Die ComboBox items met bevolk deur bewegende gemiddeldes tipes en die gebruiker vorm sal gelaai word nie. Opsie Explicit Sub loadMAForm () Met MAFormboTypeMA. RowSource. AddItem Eenvoudige. AddItem Geweegde. AddItem Eksponensiële eindig met MAForm. Show End Sub Hier is die kode toegeskryf word aan die stuur knoppie. Private Sub buttonSubmitClick () Dim inputRange, outputRange Soos Range Die inputRange sal die prys reeks gebruik word vir die berekening van die MA en die outputRange sal ingevul word met die bewegende gemiddeldes waardes bevat. Dowwe inputPeriod As Integer Die bewegende gemiddelde tydperk verklaar. Dowwe inputAddress, outputAddress As String Die toevoer en afvoer reekse verklaar as string. As comboTypeMA. Value ltgt eksponensiële en comboTypeMA. Value ltgt eenvoudig en comboTypeMA. Value ltgt Geweegde Ware Dan MsgBox Kies 'n bewegende gemiddelde tipe uit die lys. RefInputRange. SetFocus afrit Sub Hierdie deel van die proses dwing die eerste beperkings met betrekking tot die voorgelê data. As die bewegende gemiddelde tipe nie vervat is in die drop-down list, sal die prosedure nie gaan na die volgende stap en die gebruiker sal gevra word om dit weer te kies. Elseif RefInputRange. Value Dan MsgBox Kies die insette reeks. RefInputRange. SetFocus afrit Sub elseif RefOutputRange. Value Dan MsgBox Kies die uitset reeks. RefOutputRange. SetFocus afrit Sub elseif RefInputPeriod. Value Dan MsgBox Kies die bewegende gemiddelde tydperk. RefInputPeriod. SetFocus afrit Sub elseif Nie IsNumeric (RefInputPeriod. Value) Dan MsgBox Moving gemiddelde tydperk moet 'n getal wees. RefInputPeriod. SetFocus afrit Sub End Indien Ander beperkings geskep. Die insette reeks, uitset reeks en insette tydperk moet nie leeg wees. Verder moet die bewegende gemiddelde tydperk 'n aantal wees. inputAddress RefInputRange. Value Stel inputRange Range (inputAddress) outputAddress RefOutputRange. Value Stel outputRange Range (outputAddress) inputPeriod RefInputPeriod. Value Die argumente vir inputRange en outputRange wissel sal wees inputAddress en outputAddress verklaar as snare. As inputRange. Columns. Count ltgt 1 Toe MsgBox kan Inset reeks net een kolom hê. RefInputRange. SetFocus afrit Sub Die inputRange moet net een kolom bevat. Elseif inputRange. Rows. Count ltgt outputRange. Rows. Count Dan MsgBox Uitgawe reeks het 'n verskillende aantal rye as die insette reeks. RefInputRange. SetFocus afrit Sub Einde As Die inputRange en outputRange moet 'n gelyke aantal rye. Dowwe RowCount As Integer RowCount inputRange. Rows. Count Dim Kraai Soos Integer ReDim inputarray (1 tot RowCount) Vir Kraai 1 Om RowCount inputarray (Kraai) inputRange. Cells (Kraai, 1).Value Volgende Kraai inputarray verklaar as skikking en it8217s elemente stem ooreen met die waardes van elke ry van die insette reeks. As inputPeriod GT RowCount Dan MsgBox aantal uitgesoekte waarnemings is amp RowCount amp en die tydperk is amp inputPeriod amp. Die insette reeks moet 'n hoër of gelyke hoeveelheid elemente as die gekose periode nie. RefInputRange. SetFocus afrit Sub Einde As 'n ander beperking bygevoeg 8211 moet die insette reeks 'n hoër of gelyke hoeveelheid elemente as die tydperk het. As inputPeriod Dit 0 Toe MsgBox Moving gemiddelde tydperk moet hoër as 0. RefInputPeriod. SetFocus afrit Sub End wees as die bewegende gemiddelde tydperk hoër as nul moet wees. ReDim outputarray (inputPeriod Om RowCount) Soos Variant Ook die skikking dimensies van outputarray bepaal. Die ondergrens van die skikking is die inputPeriod waarde en die bogrens is die waarde van RowCount (die aantal elemente in die inputRange). Onder deel van die prosedure bereken die eenvoudige bewegende gemiddelde, as die keuse vir comboTypeMA is eenvoudig. SMA ----------------------------------------- As comboTypeMA. Value Eenvoudige Dim Ek het toe , J As Integer Dim temp Soos Double want ek inputPeriod Om RowCount temp 0 Vir j (i - (inputPeriod - 1)) Om ek temp temp inputarray (J) langs j outputarray (i) temp / inputPeriod outputRange. Cells (i, 1 ).Value outputarray (i) Volgende i outputRange. Cells (0, 1).Value SMA (amp inputPeriod amp) Eintlik is die proses bere die bewegende gemiddelde van die laaste x getalle (x gelyk aan die inputPeriod), wat begin met die element van die inputarray gelyk aan die inputPeriod. Hier is 'n vereenvoudigde voorbeeld, wat elke stap van die proses toon. In hierdie voorbeeld is daar vier getalle (no01, no02, no03 en no04) van ry 1 tot Ry 4 en die bewegende gemiddelde tydperk is 3. Na elke nuwe bewegende gemiddelde bereken word, sal elke sel van die outputRange die waarde van die neem outputarray. En ná al die bewegende gemiddeldes bereken, in die sel hierbo outputRange n titel sal plaas met die bewegende gemiddelde tipe en tydperk. Dit volgende deel sal die eksponensiële bewegende gemiddelde bereken. EMO ------------------------------------------ elseif comboTypeMA. Value Eksponensiële Dim Toe Alpha Soos Double alfa 2 / (inputPeriod 1) Vir j 1 Om inputPeriod temp temp inputarray (J) langs j outputarray (inputPeriod) temp / inputPeriod eers die waarde van Alpha word bepaal. Want in die berekening, die waarde van die EMO is gebaseer op die vorige EMO, sal die eerste een die eenvoudige bewegende gemiddelde wees. Want ek inputPeriod 1 Om RowCount outputarray (i) outputarray (i - 1) alfa (inputarray (i) - outputarray (i - 1)) Volgende i Begin met die tweede bewegende gemiddelde, sal hulle bereken word op grond van die bogenoemde formule: die vorige EMO plus alfa vermenigvuldig met die verskil tussen die huidige getal van die inputarray en die vorige EMO waarde. Want ek inputPeriod Om RowCount outputRange. Cells (i, 1).Value outputarray (i) Volgende i outputRange. Cells (0, 1).Value EMO (amp inputPeriod amp) Net soos die kode vir SMA, die outputarray sal bevolk en die sel hierbo outputarray sal die tipe en tydperk van die bewegende gemiddelde verteenwoordig. Hier is die kode vir die berekening van die geweegde bewegende gemiddelde. WBG ------------------------------------------ elseif comboTypeMA. Value Geweegde Dan Dim temp2 As Integer want ek inputPeriod Om RowCount temp 0 temp2 0 Vir j (i - (inputPeriod - 1)) Om ek temp temp inputarray (j) (j - ek inputPeriod) temp2 temp2 (j - ek inputPeriod) Volgende j outputarray (i ) temp / temp2 outputRange. Cells (i, 1).Value outputarray (i) Volgende i outputRange. Cells (0, 1).Value WBG (amp inputPeriod amp) End As die tabel hieronder bevat die stappe vir die berekening van elke veranderlike wat gebruik word vir die WBG berekening. Net soos in die vorige voorbeeld, in hierdie een is daar vir getalle in die inputRange. en die insette tydperk is 3. Hier is die finale kode van die prosedure, wat die gebruiker vorm ontlaai. Los MAForm End Sub Die volgende prosedure is vir die styl knoppie. Dit sal in dieselfde module bygevoeg word. Private Sub buttonCancelClick () los MAForm End Sub


No comments:

Post a Comment