parillinen/

pariton?

Kuinka kirjoitetaan VBA:lla
jos solu A1 on pariton, niin kopioidaan soluihin A2-A10 solujen B2-B10 arvo.
Jos ei kopioidaan soluihin A2-A10 solujen C2-C10 arvo?

Olen etsinyt netistä ties kuinka kauan VBA koodia jaollinen kaavalle, mutta tietoa olen löytänyt vain muille ohjelmointiohjelmille.

Jos jollakulla olisi hyvä sivu tiedossa, voisitteko laittaa linkkejä?

8

1194

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Piru

      Jos A1 jakojäännös 2 = 0

      niin A1 on parillinen

      Visual Basicissä jakojäännös saadaan

      jaannos = jaettava Mod jakaja

      • pariton?

        Kiitos, mutta en kyllä käsitä kuinka se toimii.
        Excelin kaavalla osaan tuon tehdä, mutta pitäisi tehdä VBA:lla ettei asetuksia muutettaisi vahingossa.
        Excelin soluja kun ei voi lukita kun silloin kaava ei toimi.


      • Kunde
        pariton? kirjoitti:

        Kiitos, mutta en kyllä käsitä kuinka se toimii.
        Excelin kaavalla osaan tuon tehdä, mutta pitäisi tehdä VBA:lla ettei asetuksia muutettaisi vahingossa.
        Excelin soluja kun ei voi lukita kun silloin kaava ei toimi.

        Public Luku As Boolean
        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        End Sub


      • tuollakaan
        Kunde kirjoitti:

        Public Luku As Boolean
        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        End Sub

        koodilla,kiitos kuitenkin. Katselin VBA:n omia ohjeita, mutta ei niistäkään mitään apuja ollut.

        Voi itku, taitaa taulukko jäädä kaava-asteelle ilman suojausta...


      • VBA
        tuollakaan kirjoitti:

        koodilla,kiitos kuitenkin. Katselin VBA:n omia ohjeita, mutta ei niistäkään mitään apuja ollut.

        Voi itku, taitaa taulukko jäädä kaava-asteelle ilman suojausta...

        kyllä taatusti toimii. Mitäs se ei tehnyt?
        Pyysit koodia jolla kopioidaan solut riipuuen A1 arvon parillisuudesta.
        Olikos syynä taulukon suojaus vai? jos niin korvaa koodi seuraavalla.
        Taulukko suojattu salasanalla 'kunde' ja solusta A1 poistettu lukitus.

        Public Luku As Boolean
        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        ActiveSheet.Unprotect Password:="kunde"
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True, Password:="kunde"
        ActiveSheet.EnableSelection = xlUnlockedCells
        End Sub


      • pariton?
        VBA kirjoitti:

        kyllä taatusti toimii. Mitäs se ei tehnyt?
        Pyysit koodia jolla kopioidaan solut riipuuen A1 arvon parillisuudesta.
        Olikos syynä taulukon suojaus vai? jos niin korvaa koodi seuraavalla.
        Taulukko suojattu salasanalla 'kunde' ja solusta A1 poistettu lukitus.

        Public Luku As Boolean
        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        ActiveSheet.Unprotect Password:="kunde"
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True, Password:="kunde"
        ActiveSheet.EnableSelection = xlUnlockedCells
        End Sub

        sain toimimaan kun laitoin painikkeen sille. Saiskos tuota toimimaan automaattisesti, että kun luku vaihtuu kopioituis solut?

        Kun kokeili ilman painiketta ei tehnyt mitään.


      • Kunde
        pariton? kirjoitti:

        sain toimimaan kun laitoin painikkeen sille. Saiskos tuota toimimaan automaattisesti, että kun luku vaihtuu kopioituis solut?

        Kun kokeili ilman painiketta ei tehnyt mitään.

        Ei koodi voi tietenkään toimia ilman tapahtumaa mikä sen käynnistäisi. No nyt koodi haluamasi taulukon moduuliin esim. taul1

        Public Luku As Boolean

        Private Sub Worksheet_SelectionChange(ByVal Target As Range)
        Testi
        End Sub

        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        Application.ScreenUpdating = False
        Application.EnableEvents = False
        ActiveSheet.Unprotect Password:="kunde"
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True, Password:="kunde"
        ActiveSheet.EnableSelection = xlUnlockedCells
        Application.EnableEvents = True
        Application.ScreenUpdating = True
        End Sub


      • pariton?
        Kunde kirjoitti:

        Ei koodi voi tietenkään toimia ilman tapahtumaa mikä sen käynnistäisi. No nyt koodi haluamasi taulukon moduuliin esim. taul1

        Public Luku As Boolean

        Private Sub Worksheet_SelectionChange(ByVal Target As Range)
        Testi
        End Sub

        Function Parillinen(Numero As Double) As Boolean
        If (Numero And 1) Then
        Parillinen = False
        Else
        Parillinen = True
        End If
        End Function

        Sub Testi()
        Application.ScreenUpdating = False
        Application.EnableEvents = False
        ActiveSheet.Unprotect Password:="kunde"
        If Not Parillinen(Range("A1")) Then
        Range("B2:B10").Copy Destination:=Range("A2")
        Else
        Range("C2:C10").Copy Destination:=Range("A2")
        End If
        ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True, Password:="kunde"
        ActiveSheet.EnableSelection = xlUnlockedCells
        Application.EnableEvents = True
        Application.ScreenUpdating = True
        End Sub

        Tosi suuret kiitokset, nyt alkoi toimimaan haluamallani tavalla!


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

    Luetuimmat keskustelut

    1. Mitään järkeä?

      Että ollaan erillään? Kummankin pää on kovilla.
      Ikävä
      127
      2004
    2. Noniin rakas

      Annetaanko pikkuhiljaa jo olla, niin ehkä säilyy vienot hymyt kohdatessa. En edelleenkään halua sulle tai kenellekään mi
      Ikävä
      102
      1785
    3. Kumpi vetoaa enemmän sinuun

      Kaivatun ulkonäkö vai persoonallisuus? Ulkonäössä kasvot vai vartalo? Mikä luonteessa viehättää eniten? Mikä ulkonäössä?
      Ikävä
      83
      1601
    4. Lasten hyväksikäyttö netissä - Joka 3. nuori on saanut seksuaalisen yhteydenoton pedofiililtä

      Järkyttävää! Lapsiin kohdistuva seksuaalinen hyväksikäyttö verkossa on yhä pahempi ongelma. Ulkolinja: Lasten hyväksikäy
      Maailman menoa
      61
      1454
    5. Multa sulle

      Pyörit 24/7 mielessä, kuljet mun mukana, mielessä kyselen sun mielipiteitä, vitsailen sulle, olen sydän auki, aitona. M
      Ikävä
      33
      1152
    6. Tavoitteeni onkin ärsyttää

      Sua niin turhaudut ja unohdat koko homman
      Ikävä
      110
      1083
    7. Nainen, olen tutkinut sinua paljon

      Salaisuutesi ei ole minulle salaisuus. Ehkä teimme jonkinlaista vaihtokauppaa kun tutkisimme toisiamme. Meillä oli kumm
      Ikävä
      51
      1053
    8. Mies, eihän sulla ole vaimoa tai naisystävää?

      Minusta tuntuu jotenkin, että olisit eronnut joskus, vaikka en edes tiedä onko se totta. Jos oletkin oikeasti edelleen s
      Ikävä
      47
      1046
    9. Ei se mene ohi ajan kanssa

      Näin se vaan on.
      Ikävä
      73
      1036
    10. Onko sulla empatiakykyä?

      Etkö tajua yhtään miltä tämä tuntuu minusta? Minä ainakin yritän ymmärtää miltä sinusta voisi tuntua. En usko, että olet
      Ikävä
      44
      983
    Aihe