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

455

    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. 6 kW saunan lämmityksestä kohta 10 euron lisämaksu / kerta

      Kokoomuslainen sähköyhtiöiden hallitsema Energiavirasto ehdottaa 5 kW:n rajaa, jonka ylittämisestä tulee lisämaksu. Tark
      Maailman menoa
      147
      5554
    2. Minja jytkyttää vas.liiton kannatusta ylöspäin

      Alkaa raavaat duunarimiehetkin palaamaan vasemmistoliiton kannattajiksi. Eduskunnassahan on vain kaksi työntekijöiden p
      Maailman menoa
      138
      3617
    3. "Mitä sä nainen tuot sitten pöytään" ?

      Jos mies provaidaa ja suojelee... Pitääkö miesten kysyä tuollaisia?
      Ikävä
      126
      3359
    4. Ekologinen kommunismi tulee voittamaan fossiilikapitalismin

      Kiina on mahtitekijä uusiutuvien energialähteiden kehityksessä, ja Trump osoitus viimeisestä öljyn perään itkemisestä, m
      Maailman menoa
      36
      3223
    5. Mies, kerro minulle vielä jotakin aivan uniikkia

      ja ainutlaatuista minkä vain me kaksi voisimme ymmärtää jos olemme sen kokeneet ja eläneet, jotta ihan varmasti tietäisi
      Tunteet
      45
      2742
    6. Oikeistopuolueiden kannatus vain 37,8 %, vasemmiston 43,0 %

      Keskustaan jää 17,4 prosenttia ja loput ovat sitten mitä ovat. Mutta selvästikin Suomen kansa on vasemmalle kallellaan.
      Maailman menoa
      51
      2314
    7. Tiedän ettei

      Meistä mitään tule. Toinen oli sinulle tärkeämpi
      Ikävä
      24
      2250
    8. Hyviäkin uutisia tulossa, hallinto-oikeus asettaa toimeenpanokieltoon

      Hyvinvointitalon työmaa pysähtyy. Rillankivi+energia ja vesi kytkyrahanpesu stoppaa. Tytäryhtiöiden hallitusjäsenet+kon
      Pyhäjärvi
      230
      2202
    9. prööt prööt nyt ottaa vihervassaria pattiin!

      Korvatkaa R kirjaimet L kirjaimilla ja sanokaa ääneen "Jari Kurri etsii pakoputkiautossaan jarruja".
      Maailman menoa
      11
      1944
    10. Gallup: Mikä on ollut mielestäsi paras tv-sarja ikinä?

      Gallup: Mikä on ollut mielestäsi paras tv-sarja ikinä? Onko se joku suomalainen viihdepläjäys, brittirikossarja, amerikk
      Tv-sarjat
      93
      1826
    Aihe