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

1215

    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. Sanna Marin kysyi hämmästyneenä: Onko Suomessa jäänmurtajia?

      Nettilehden toimittaja kysyi Sanna Marinilta suoraan, että sovittiinko nuo jäänmurtajien kaupat jo 2019, jolloin Marin k
      Maailman menoa
      128
      4496
    2. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      155
      3769
    3. SDP haluaa 40 000 nettomaahanmuuttajaa

      SDP:n Suunnanmuutos-vaihtoehtobudjetissa, käy ilmi, että demarit itse asiassa vaativat räjähdysmäistä ”työperäisen” maah
      Maailman menoa
      103
      3506
    4. Mikä tuota vasemmistolaisista jankkaavaa vaivaa?

      Pahasti on ihon alle, siis korvien väliin, päässeet kummittelemaan. Ei ole terveen ihmisen merkki jankata yhdestä asia
      Maailman menoa
      41
      2859
    5. Mitä ajattelit kun näit

      kaivattusi ensimmäisen kerran? xd
      Ikävä
      136
      1806
    6. Nyt meni lopulliset lämmöt.

      Alan käyttäytymään yhtä kylmästi miehiä kohtaan kuin mua kohtaan on käyttäydytty ja vain käytetty viimeiset pari vuotta
      Sinkut
      38
      1602
    7. Orpo loukkaantui fasismiin viittaavasta sanavalinnasta

      Mutta miksi loukkaantui? Orpohan on tehnyt yhteistyötä fasistien kanssa jo vuonna 2019, siis jo neljä vuotta ennen loukk
      Maailman menoa
      25
      1258
    8. Sulla on avaimet ja keinot

      Jos haluat jatkaa tutustumista. Itse olen niin jäässä etten pysty tekemään enää mitään. Pidempi keppi johon on helpompi
      Ikävä
      21
      1231
    9. Meitä ei tule

      Koska periaatteemme ovat rakkautta vahvempia. Tämä on siis koettelemus, jonka tarkoitus on vahvistaa meitä yksilöinä 😌
      Ikävä
      23
      1173
    10. Onko erityinen paikka jossa haluaisit nyt olla

      Onko joku spesiaali lempipaikka missä mieluiten olisit?
      Ikävä
      42
      1165
    Aihe