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

1112

    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. Monenko kanssa olet harrastanut seksiä

      tänä aikana kun olet kaivattuasi kaipaillut?
      Ikävä
      129
      3267
    2. Melkein lähetin viestin.

      Onneksi tulin järkiini. Mukavaa kesää
      Ikävä
      109
      1311
    3. Timo Soini tyrmää Tynkkysen selitykset Venäjän putinistileiristä

      "Soini toimi ulkoministerinä ja puolueen puheenjohtajana vuonna 2016, jolloin silloinen perussuomalaisten varapuheenjoht
      Maailman menoa
      267
      1285
    4. Sulla on nainen muuten näkyvät viiksikarvat naamassa jotka pitää poistaa

      Kannattaa katsoa peilistä lasien kanssa, ettet saa ihmisiltä ikäviä kommentteja.
      Ikävä
      65
      1096
    5. Nainen voi rakastaa

      Ujoakin miestä, mutta jos miestä pelottaa näkeminenkin, niin aika vaikeaa on. Semmoista ei varmaan voi rakastaa. Miehelt
      Ikävä
      79
      1061
    6. Kalateltta fiasko

      Onko Tamperelaisyrittäjälle iskenyt ahneus vai mistä johtuu että tänä vuonna ruuat on surkeita aikaisempiin vuosiin verr
      Kuhmo
      14
      1056
    7. IS Viikonloppu 20.-21.7.2024

      Tällä kertaa Toni Pitkälä esittelee piirrostaitojansa nuorten pimujen, musiikkibändien ja Raamatun Edenin kertomusten ku
      Sanaristikot
      57
      979
    8. Rakastan sinua

      Olen tiennyt sen pitkään mutta nyt ymmärsin että se ei menekään ohi
      Ikävä
      30
      976
    9. Ikävöimäsi henkilön ikä

      Minkä ikäinen kaipauksen kohteenne on? Onko tämä vain plus 50 palsta vai kaivataanko kolme-neljäkymppisiä? Oma kohde mie
      Ikävä
      42
      944
    10. Liikenne onnettomuus

      Annas kun arvaan -Nuoriso -Ajokortti poikkeusluvalla -Ylinopeus
      Orimattila
      46
      854
    Aihe