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

463

    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. Mikä on sun mielestä suurin kusetus maailmassa?

      Mikä on sun mielestä suurin kusetus maailmassa?
      Ikävä
      222
      14806
    2. Uusnatsien ilkivalta Joensuussa jatkuu.

      Saavat mellastaa persujen suojissa miten haluavat. Särkevät ja tuhoavat toisten omaisuutta, tähän on johtanut persujen m
      Joensuu
      19
      2189
    3. Voima biisejä, mikä antaa hyvää mieltä ja vomaannuttaa

      Mikä antaa voimaa ja hyvää mieltä, jos tuntuu hankalalta ja vaikealta, voima biisi tai biisejä?
      Ikävä
      38
      1873
    4. Kysy jotain kaivatultasi

      Tämä ketju on sitä varten.
      Ikävä
      137
      1242
    5. Huomenna sähkö maksaa jo yli 60 snt/kWh. Milloin ALV putoaa?

      Kysynkin persuilta, että milloin aiotte pudottaa sähkön arvonlisäveron kuten Marinin hallitus teki sähkön hinnan noustes
      Maailman menoa
      95
      1220
    6. Varmaan koet, ettet ole tehnyt mitään väärää

      Mutta olet sinä tehnyt.
      Ikävä
      22
      1100
    7. Huomioon ottaminen

      Oletko osannut ottaa kaivattusi tai hänen (mahdolliset) tunteet huomioon? Oletko sivuuttanut ne tarkoituksella tai vahin
      Ikävä
      30
      892
    8. Mitä ajattelet hänestä

      Millaisena pidät kaivattuasi?
      Ikävä
      73
      775
    9. Sinkkusiskoni pliis kertokaa

      Sinkkunaisena haluaisin joskus normaalia läheisyyttä ja yhdessäoloa, ilman velvoitteita. Olen vapaa ja lapseton, eikä ex
      Sinkut
      80
      713
    10. Nainen, se on sellainen juttu että kun sä vain nautit

      Niin me miehet tehdään ne työt että sä voisit nauttia. Kato siinä ku sä meet mukamas töihin suojatyöpaikkaas lämpimään t
      Ikävä
      80
      698
    Aihe