Vba

taas pulassa

Tein koodin pätkän, joka vertaa samalla rivillä olevia numeroita yhteen lukuun. Jos jokin luku on yhtä suuri kuin verrattava luku, suorittaa excel tietyn toiminnon.

Nyt kun rivejä exceliin tulee ainakin 30, niin miten saisin kätevästi tämän toiminnon kaikille riveille, niin ettei minun tarvitse kirjoittaa jos-lauseketta joka rivistä erikseen Vba:han?

7

465

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • hiukan ylimalkainen kyssäri , mutta rivit joilla vastine on saat kätevästi allaolevalla koodilla(vanha postaus tänne ). Siinä sitten vaan tsekkaat rivitiedon ja suoritat tarvittavan makron(ilmeisesti sama kaikilla?)

      moduuliin...

      Option Explicit

      Sub Siirrä()
      Dim Löydetty As Range
      Dim solu As Range
      Dim haku As Variant
      On Error Resume Next
      Application.ScreenUpdating = False
      Worksheets("Sheet1").Activate
      haku = 1
      Set Löydetty = EtsiJaSiirrä(haku, Rows("1:30"))
      For Each solu In Löydetty
      'tähän makrotestaus soluosoitteen mukaan(rivi) ...
      MsgBox solu.Row
      Next
      Range("A1").Select
      Application.ScreenUpdating = True
      End Sub


      Function EtsiJaSiirrä(Hakuehto As Variant, HakuAlue As Range) As Range
      Dim solu As Range
      Dim EkaOsoite As String

      With HakuAlue
      Set solu = .Find( _
      What:=Hakuehto, _
      LookIn:=xlValues, _
      LookAt:=xlWhole, _
      SearchOrder:=xlByRows, _
      SearchDirection:=xlNext, _
      MatchCase:=False, _
      SearchFormat:=False)
      If Not solu Is Nothing Then
      Set EtsiJaSiirrä = solu
      EkaOsoite = solu.Address
      Do
      Set EtsiJaSiirrä = Union(EtsiJaSiirrä, solu)
      Set solu = .FindNext(solu)
      Loop While Not solu Is Nothing And solu.Address EkaOsoite
      End If
      End With
      End Function

      • taas pulassa

        Sorry, selitin huonosti.

        Eli otetaan esimerkki, jossa A1=1, B1=2 ja C1=3.
        Jos A1 tai B1 olisi 3, tulisi ruutuun varoitusteksti. Tämän osaan tehdä.

        Eli soluja A ja B verrataan aina soluun C, joka rivillä solut A, B ja C saavat eri arvot.

        Miten siis saan n. 30:lle riville kopioitua tämän toiminnon? kun ei viitsisi kirjoittaa 30 if lausetta, toisin sanoen 30 makroa.


      • taas pulassa kirjoitti:

        Sorry, selitin huonosti.

        Eli otetaan esimerkki, jossa A1=1, B1=2 ja C1=3.
        Jos A1 tai B1 olisi 3, tulisi ruutuun varoitusteksti. Tämän osaan tehdä.

        Eli soluja A ja B verrataan aina soluun C, joka rivillä solut A, B ja C saavat eri arvot.

        Miten siis saan n. 30:lle riville kopioitua tämän toiminnon? kun ei viitsisi kirjoittaa 30 if lausetta, toisin sanoen 30 makroa.

        eli onko tarkoitus tarkistella sarakkeisiin A tai B syötettäviä arvoja ja verrata saman rivin C sarakkeen arvoon ja jos A:han tai B:hen syötettävä arvo on saman rivin C sarakkeen solussa niin varoitus?
        Jos näin niin vaihtoehtoja on...
        mutta odotellaan tarkennusta ennen kuin vastataan


      • taas pulassa
        kunde kirjoitti:

        eli onko tarkoitus tarkistella sarakkeisiin A tai B syötettäviä arvoja ja verrata saman rivin C sarakkeen arvoon ja jos A:han tai B:hen syötettävä arvo on saman rivin C sarakkeen solussa niin varoitus?
        Jos näin niin vaihtoehtoja on...
        mutta odotellaan tarkennusta ennen kuin vastataan

        Juurikin tuosta on kysymys. Msgbox hypähtää silmille, jos joku arvoista on sama, mutta miten tämän saa toimimaan rivikohtaisesti, niin ettei minun tarvitse kirjoittaa if-lauseketta joka rivistä erikseen?


      • taas pulassa kirjoitti:

        Juurikin tuosta on kysymys. Msgbox hypähtää silmille, jos joku arvoista on sama, mutta miten tämän saa toimimaan rivikohtaisesti, niin ettei minun tarvitse kirjoittaa if-lauseketta joka rivistä erikseen?

        ko. TAULUKON moduuliin...

        Private Sub Worksheet_Change(ByVal Target As Range)
        If Not Intersect(Target, Columns("A:A")) Is Nothing Then
        If Target = Target.Offset(0, 2) Then
        MsgBox "Arvo ei kelvollinen!", vbInformation
        Target = ""
        Target.Select
        End If
        End If
        If Not Intersect(Target, Columns("B:B")) Is Nothing Then
        If Target = Target.Offset(0, 1) Then
        MsgBox "Arvo ei kelvollinen!", vbInformation
        Target = ""
        Target.Select
        End If
        End If
        End Sub

        Keep Excelling
        @Kunde


      • taas pulassa
        kunde kirjoitti:

        ko. TAULUKON moduuliin...

        Private Sub Worksheet_Change(ByVal Target As Range)
        If Not Intersect(Target, Columns("A:A")) Is Nothing Then
        If Target = Target.Offset(0, 2) Then
        MsgBox "Arvo ei kelvollinen!", vbInformation
        Target = ""
        Target.Select
        End If
        End If
        If Not Intersect(Target, Columns("B:B")) Is Nothing Then
        If Target = Target.Offset(0, 1) Then
        MsgBox "Arvo ei kelvollinen!", vbInformation
        Target = ""
        Target.Select
        End If
        End If
        End Sub

        Keep Excelling
        @Kunde

        Mitä nuo Offset arvot tarkoittavat? (0,2) ja (0,1)?


      • taas pulassa kirjoitti:

        Mitä nuo Offset arvot tarkoittavat? (0,2) ja (0,1)?

        If Target = Target.Offset(0, 2)

        eli kun joku solu muuttuu taulukossa(=Target , tossa koodissani) niin aluksi siinä oli testaus onko kyseessä A sarakkeen solu, joka muuttuu ja jos oli, niin sitten verrataan sitä saman rivin C sarakkeen soluun
        Target.Offset(0, 2) eli siirtymä 0 =sama rivi ja 2 =2 saraketta oikealle
        rivit menee alaspäin ja - ylöspäin vastaavasti sarakkeet oikealle ja -vasemmalle.

        elikä koodi aktivoituu kun taulukossa joku arvo muuttuu
        ekaksi testataan oliko A sarakkeen solu ja jos oli niin onko arvo sama kuin C sarakkeessa ja jos oli niin ilmoitus
        jälkimmäinen osa vastaavasti B sarakkeen soluille

        Keep Excelling
        @Kunde


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

    Luetuimmat keskustelut

    1. Riikka Purra lupasi Suomen kansalle 1 euron bensaa, hinta nyt 2 euroa

      Vasemmistolaisen Marinin hallituksen aikana bensa ei maksanut kuin 1,3 euroa litralta. Ministerin pitäisi perustuslain m
      Maailman menoa
      272
      5380
    2. Kohdataanko me

      Enää?
      Ikävä
      70
      4926
    3. Suvi Lindenillä 5 366 päivän putki

      Täytyy kyllä myöntää vaikka olen itsekin innokas, niin en ole tuollaiseen yli kymmenen vuoden putkeen kyennyt. Välillä o
      Maailman menoa
      123
      4365
    4. Rakkaalle miehelle

      Terveiset rakas. Ikävä on edelleen. Suru valtaa sydämen, kun en saa lähestyä sinua. En saa vastauksia, en soittoa, viest
      Ikävä
      48
      4036
    5. Eräs on taas viettänyt kokoyön täällä!!

      Etkö sä nuku koskaan??
      Ikävä
      51
      3810
    6. Mistä se kertoo

      Näin miehen pitkästä aikaa. Samantien iski sellainen paineen tunne rintaan, sitä ei ole ollut vuosiin. Ja nyt olen siitä
      Ikävä
      36
      3697
    7. Olipa turha tämä

      Rakkaustarinamme
      Ikävä
      41
      3388
    8. SDP:n kansanedustaja Nazima Radmyar uhriutuu somessa saamistaan viesteistä.

      https://www.is.fi/politiikka/art-2000011854410.html Miksi Razmyar ei kestä kansan palautetta oikean kansanedustajan tavo
      Maailman menoa
      86
      3086
    9. Muistatteko kuinka Marinin hallituksen aikaan kansalaisilla oli varaa kuluttaa?

      Tavallisella perheelläkin oli rahaa käydä sääännöllisesti ravintoloissa syömässä, koska vahvat ammattiliitot olivat neuv
      Maailman menoa
      65
      2948
    10. Nyt on sanottava että sattuu kipeästi

      Jos, sinä aikana kun olen kaivannut ja odottanut sinua ja olet tiennyt sen, niin jos valitsit toisen miehen. Katsot minu
      Ikävä
      23
      2688
    Aihe