Laskentapäivitys heti makrolla, miten?

autopäivitys

Kun Nyt-funktio vaihtaa hetken määritellyn rajan yli, tapahtuu laskenta. F9- näpäyksellä saa ajan muuttumisen näkymään koskematta soluihin, mutta nyt tarvittaisiin tilanteen ajantasalle saaminen koskematta tietokoneeseen:
Excel käynnissä, kello raksuttaa, solussa aika etenee vaikka ei paineta F9, ja sitten kun klo menee yli rajan, tapahtuu jos-funktioon määrätyt laskennat.

Mitkä makrokomennot tekisivät tämän Nyt-funktion ajan tasalla pysymisen ilman F9 näpäystä?

17

325

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Mr. VBA

      Moi, laita Excel käynnistämään makro automaattisesti haluamanasi raja-aikana.
      reaaliajassa toimiva kello voi viedä turhaan tehoja koneesta.

      ThisWorkbook kohtaan seuraava:

      Private Sub Workbook_Open()

      'solussa A1 haluttu alkamisaika makrolle nimeltä Päämakro
      'voi laittaa myös suoraan sulkeisiin ajan muodossa TimeValue("13:15:00")

      On Error Resume Next

      Dim Aika As Date
      Aika = Range("A1").Value

      Application.OnTime TimeValue(Aika), "PääMakro"

      End Sub

      ja moduuliin esim.

      Sub PääMakro()

      MsgBox "aloitetaan laskenta"
      ' tähän koodia

      End Sub

      • Autopäivitys

        Kiitos, Mr VBA, tutkiskelen, opiskelen ohjettasi


      • jos tallennatkin jonkun muun kuin sun ajatuksissasi olleen taulukon ollessa aktiivinen, niin mitäs tapahtuu seuraavalla kerralla kun avaat ExCELin... ;-)
        ei hjuva

        Keep EXCELing
        @Kunde


    • Mr. VBA

      Moi, laita vielä alla oleva lisäys mukaan, jotta makro ei käynnisty myöhemmin automaattisesti itsekseen työkirjan sulkemisen jälkeen (=tämä voi muutoin tapahtua, jos olet sulkenut työkirjan ennen kuin ajastettu makro on suoritettu)

      ThisWorkbook kohtaan seuraava:

      Private Sub Workbook_BeforeClose(Cancel As Boolean)

      On Error Resume Next
      Dim Aika As Date
      Aika = Range("A1").Value

      Application.OnTime TimeValue(Aika), "PääMakro", , False

      End Sub

    • Mr. VBA

      Moi Kunde, ei mitään. Kerrotko tarkemmin mitä sinulla tapahtui ?

      • "Moi Kunde, ei mitään."

        Aivan oikein! Ei tapahdu mitään

        Aika = Range("A1").Value

        jos oletuksena oli vaikka Taul1 ja siellä toi arvo haetaan, toimiii niin kauan oikein kun olet tallentanut EXCELin Taul1 ollessa aktiivinen. Jos sen sijaan tallennat esim. Taul2 ollessa aktiivinen, ei toimi koska A1 arvo luetaan aktiivisesta taulukosta ja todennäköisesti muissa taulukoissa ei ole tota aikaa A1:ssa

        ymmärsitkö pointtini?


        Keep EXCELing
        @Kunde


    • Mr. VBA

      Moi, tuo ongelma pois kun laittaa alla olevan aikaisemman sijaan:

      ThisWorkbook kohtaan seuraava:

      Private Sub Workbook_Open()

      'ensimmäisellä välilehdellä solussa A1 haluttu alkamisaika makrolle nimeltä Päämakro
      'voi laittaa myös suoraan sulkeisiin ajan muodossa TimeValue("13:15:00")

      On Error Resume Next

      Dim Aika As Date
      Aika = ActiveWorkbook.Sheets(1).Range("A1").Value

      Application.OnTime TimeValue(Aika), "PääMakro"

      End Sub

      Ymmärsin ensimmäisen viestisi kyllä aivan erilailla..

    • Mr. VBA

      vielä ThisWorkbook kohtaan sama tarina, ettei itsekseen käynnistele:

      Private Sub Workbook_BeforeClose(Cancel As Boolean)
      On Error Resume Next
      Dim Aika As Date
      Aika = ActiveWorkbook.Sheets(1).Range("A1").Value
      Application.OnTime TimeValue(Aika), "PääMakro", , False
      End Sub

      Pääseekö näillä eteenpäin "Autopäivitys" ?

      • Autopäivitys

        Vähän tökkii eli testimakro ei käynnisty automaattisesti. Missäköhän mulla on virhe:

        Soluun A1 laitan ajan muodossa pv ja klo, siis:
        30.4.2013 9:39:00

        Vbasicissa kohdassa: Tämä työkirja:

        Private Sub Workbook_Open()

        'solussa A1 haluttu alkamisaika makrolle nimeltä tietoa
        'Application.OnTime TimeValue(Aika), "Tietoa"

        On Error Resume Next

        Dim Aika As Date
        Aika = Range("A1").Value

        Application.OnTime DateValue(Aika), "Tietoa"

        End Sub

        Moduliin laitettuna:


        Sub Tietoa()
        '
        ' tekstiä_E_H_alueelle Makro
        Range("E5:H24").Select
        Selection.FormulaR1C1 = "Tekstiä"
        End Sub


        Tilanne tarkemmin:
        Kone ja tiedosto ja välilehti koko ajan käynnissä, kyseessä näyttöruutu työntekijöille


    • Mr.VBA

      Moi, Ajastuksen aktivoi tässä aina tiedoston avaaminen, eli avaus pitää tehdä aina aluksi. Koodista sen verran, että DateValue pitää olla TimeValue. Alla yhteenvetona koodia. Miten nyt toimii ?

      ThisWorkbook kohtaan:

      Private Sub Workbook_Open()
      On Error Resume Next
      Dim Aika As Date
      Aika = ActiveWorkbook.Sheets(1).Range("A1").Value
      Application.OnTime TimeValue(Aika), "Tietoa"
      End Sub

      Private Sub Workbook_BeforeClose(Cancel As Boolean)
      On Error Resume Next
      Dim Aika As Date
      Aika = ActiveWorkbook.Sheets(1).Range("A1").Value
      Application.OnTime TimeValue(Aika), "Tietoa", , False
      End Sub

      Moduuliin:

      Sub Tietoa()
      ' tekstiä_E_H_alueelle Makro
      Range("E5:H24").Select
      Selection.FormulaR1C1 = "Tekstiä"
      End Sub

    • Voin kyllä ilman testausta sanoa, että Mr.VBAn koodi ei toimi kuin kerran ja siis ja vain kun avataan tiedosto. Ja toimii silloinkin vain jos avauksessa solussa oleva aika on "tulevaisuudessa"

      Toisaalta kysymyshän oli miten korvata F9 napin painallus, jos solussa aika muuttuu ja raja ylittyy
      ihan piece of case, mutta katsotaan miten Mr.VBA ratkaisee hommat...
      jos ei onnaa, niin ehkäpä Kunde auttaa...


      muuten HYVÄÄ VAPPUA KAIKILLE etenkin mun foorumin lukijoille!

      KEEP EXCELing
      @Kunde

      • Mr.VBA

        Moi, tiedosto tarvitsee avata vain kerran. Kannattaa kunde testata. Ajattelin aikaisemmin työntekijää, joka tulee ysiltä töihin ja avaa koneen ja tiedoston ja sulkee koneen viideltä. Mutta jos tiedosto kokoajan siis auki, niin toimii joka vuorokausi samaan aikaan vaikka A1 pvm formaatti olisi 1950-luvulla. Kelloaika merkitsee;)

        Mutta ..tässä kuitenkin koodia aikaisemman sijasta ja makro, jossa haluttu aloitus-aika. Tiedosto auki ja kellonaika moduuli vaan päälle. testauskommentit ?

        ThisWorkbook kohtaan:
        Private Sub Workbook_BeforeClose(Cancel As Boolean)
        Dim LisääAikaa As Date
        LisääAikaa = TimeValue("00:00:01") Now
        On Error Resume Next
        Application.OnTime LisääAikaa, "KellonAika", , False
        End Sub

        Moduuleihin:

        Sub KellonAika()
        Dim LisääAikaa As Date
        Dim Käyntiin As Date
        'alle haluttu käynnistys-aika joka vuorokausi
        Käyntiin = ("23:59:59")
        ActiveWorkbook.Sheets(1).Range("A1").Value = Time
        If Time = Käyntiin Then Tietoa
        LisääAikaa = TimeValue("00:00:01") Now
        Application.OnTime LisääAikaa, "KellonAika"
        End Sub

        Sub Tietoa()
        ' tekstiä_E_H_alueelle Makro
        Range("E5:H24").Select
        Selection.FormulaR1C1 = "Tekstiä"
        End Sub


      • Mr.VBA kirjoitti:

        Moi, tiedosto tarvitsee avata vain kerran. Kannattaa kunde testata. Ajattelin aikaisemmin työntekijää, joka tulee ysiltä töihin ja avaa koneen ja tiedoston ja sulkee koneen viideltä. Mutta jos tiedosto kokoajan siis auki, niin toimii joka vuorokausi samaan aikaan vaikka A1 pvm formaatti olisi 1950-luvulla. Kelloaika merkitsee;)

        Mutta ..tässä kuitenkin koodia aikaisemman sijasta ja makro, jossa haluttu aloitus-aika. Tiedosto auki ja kellonaika moduuli vaan päälle. testauskommentit ?

        ThisWorkbook kohtaan:
        Private Sub Workbook_BeforeClose(Cancel As Boolean)
        Dim LisääAikaa As Date
        LisääAikaa = TimeValue("00:00:01") Now
        On Error Resume Next
        Application.OnTime LisääAikaa, "KellonAika", , False
        End Sub

        Moduuleihin:

        Sub KellonAika()
        Dim LisääAikaa As Date
        Dim Käyntiin As Date
        'alle haluttu käynnistys-aika joka vuorokausi
        Käyntiin = ("23:59:59")
        ActiveWorkbook.Sheets(1).Range("A1").Value = Time
        If Time = Käyntiin Then Tietoa
        LisääAikaa = TimeValue("00:00:01") Now
        Application.OnTime LisääAikaa, "KellonAika"
        End Sub

        Sub Tietoa()
        ' tekstiä_E_H_alueelle Makro
        Range("E5:H24").Select
        Selection.FormulaR1C1 = "Tekstiä"
        End Sub

        Miksi noin monimutkaisesti, jos Excel auki kokoajan ja 00:00:00 tapahtuu makron suoritus?

        yksi helppo keino olisi käyttää Windowsin omaa ajastettua toimintaa ja silloin Excel voi olla suljettuna kokoajan. Toki, jos pitää lukea dataa jostain kokoajan niin ei voi käyttää. Mutta jos esim. juuri, ennen makron suoritusta voidaan lukea dataa sisään silloin tekisin itse tällä, koska ei tartte Excelin olla auki resursseja viemässä.
        siis START/ ADMINISTRATIVE TOOLS/ SHEDULE TASK ja siellä lisäät ton Excelin avaamisen ja Auto-Open tapahtumaan tarvittavat koodit ...


        Keep EXCELing
        @Kunde


      • kunsepuu

        Toisaalta kysymyshän oli miten korvata F9 napin painallus, jos solussa aika muuttuu ja raja ylittyy
        kuinkas to inyt käynnistää makron?
        ei siinä tartte tommosia...
        ei vastaa kysymykseen ;-)

        KEEP EXCELing
        @Kunde


    • autopäivistys

      Tilanne siis:
      Excel-tiedosto on koko ajan käynnissä ja näkyvissä ja ilman F9- nappia pitäisi saada laskenta ajantasalle klon mukaan eli tarkemmin vuorokauden vaihtuessa.
      Ihan alussa mainitsin, että Excel pysyy käynnissä.

      Itsekin osaan tehdä makron, joka automaattisesti rullaa kun tiedoston käynnistää, se on nimellä auto open.
      Tämä vaan nyt ei riitä.

      Kiitos asiaa pohtineille.

      Mites, Kunde, jos kerrot tämän sivuillasi, mikä on osoite?

    • autopäivitys

      Tämä viestiketju päivittyy vähän kummallisessa järjestyksessä.

      Mutta kiitos VBA ja Kunde, yritän käyttää teidän ohjeitanne ja kerron miten kävi.

    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. V*ttuu että mä haluan sua

      Jos jotain ihmistä voi kunnolla haluta, niin hän on se. Voi Luoja auta jo! Joku jeesus hjelppa mej!
      Ikävä
      106
      5775
    2. Nolointa ikinä miehelle

      On ghostata nainen jonka kanssa on ollut ystävä tai ollu orastavaa tapailua pidemmän aikaa. Osoittaa sellaista moukkamai
      Ikävä
      183
      4853
    3. Mikä sinua eniten

      Huolestuttaa tässä tilanteessa?
      Ikävä
      121
      3580
    4. Koska olet viimeksi nähnyt ikävän kohteesi?

      Ja mitä tarjoat hänelle kun koputtaa oveesi?
      Ikävä
      69
      2733
    5. Sattuma ja muutama väärinkäsitys

      vaikuttivat siihen millaiseksi tämä kaikki muodostui. Pienet aikanaan huomaamattomat käänteet. Seuraava näytös on jo tul
      Ikävä
      57
      2551
    6. On sillä rääpyä

      Tuo ex kuntajohtaja Lea Tolonen kehtaakin tulla Ähtäriin. Ajoi laivan Karille. Kari Heikkilä oikaisi taloutta, sai laiva
      Ähtäri
      21
      1983
    7. Kolmas kerta toden sanoo

      Näinhän sitä sanotaan. 🤭
      Ikävä
      34
      1634
    8. Toisesta ketjusta syntyi ajatuksia

      Annan lähes koko elämäni hänen vuokseen. Alan miettiä olenko menettänyt järkeni enkä vain huomaa sitä? Hyväkin asia mikä
      Ikävä
      14
      1303
    9. Mussu näytti taas

      oikein hyvältä...
      Ikävä
      10
      1284
    10. Vähän kädet tärisee

      Näköjään vieläkin ❤️ onko meidän välillä vielä jännitettä vai ei?
      Ikävä
      10
      1242
    Aihe