Excel lookup-kysymys

Ari

Voinko tehdä jotenkin näppärästi haun taulukkoon, jossa vaaka- ja pystyrivien otsikot ovat tekstimuotoisia (ja niiden risteyksessä tietysti se haettava arvo).

Onnistuuko? Miten?

-Ari

13

3242

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • mites

      tämmöinen yhdistelmä phaku ja vastine funktioita.Voi olla ettei tämä sovi sinun taulukkoosi mutta voithan soveltaa

      PHAKU(B9;A1:E5;VASTINE(B8;A1:E1;0);0)

      B8 sarakeotsikko
      B9 riviotsikko

      • Ari

        Mitäs noi PHAKU ja VASTINE on englanniksi...?

        -Ari


      • nuo
        Ari kirjoitti:

        Mitäs noi PHAKU ja VASTINE on englanniksi...?

        -Ari

        phaku = vlookup
        vastine = match


    • Kunde

      Valitse hakualue ja valitse Lisää/Nimi/Luo ja avautuvasta valikosta oikeat vaihtoehdot luo nimille. Kun haluat hakea arvoa kirjoitat vain soluun kaavan = sarakeotsikko riviotsikko tai toisten päin =riviotsikko sarakeotsikko :)

      • mites

        on näppärä tapa hoitaa asia, hienoa !


      • paavali

        aivan uusi asia minullekin, mutta käy moneen hakuun


      • Kunde
        paavali kirjoitti:

        aivan uusi asia minullekin, mutta käy moneen hakuun

        Tota leikkaus funktiota kutsutaan Excelin Native Languageksi...
        Ollos hyvä vaan! :)


      • paavali
        Kunde kirjoitti:

        Tota leikkaus funktiota kutsutaan Excelin Native Languageksi...
        Ollos hyvä vaan! :)

        Onnistuuko sama "oikelta vasemmalle"
        esim.Sarakeotsikot: nimi, pituus, paino
        Löytyykö joku konsti etsiä kuka painaa 63kg


      • paavali
        paavali kirjoitti:

        Onnistuuko sama "oikelta vasemmalle"
        esim.Sarakeotsikot: nimi, pituus, paino
        Löytyykö joku konsti etsiä kuka painaa 63kg

        INDEKSI(VASTINE) hakee kyllä, mutta onnistuuko tuolla toisella tavalla.


      • Kunde
        paavali kirjoitti:

        INDEKSI(VASTINE) hakee kyllä, mutta onnistuuko tuolla toisella tavalla.

        Mutta tällä voi hakea taulukosta kanssa mistä sarakkeesta tahansa :)

        Function PHakuVasemmalle(Hakuarvo, ByVal Hakutaulukko As Range, _
        PalArvoSarakeSiirtymä As Integer, _
        Optional HakuarvoSarake As Integer = -257)
        ' Tämä funktio hakee arvoja vasemmalta tai oikealta
        ' Kun määrittelet neljännen arvon voit käyttää mitä tahansa saraketta
        ' Kolmas argumentti on sarakkeiden määrä siirtymänä vasemmanpuoleisesta
        ' sarakkeesta (0 -pohjainen).Esim 1 palauttaa toisen sarakkeen arvon


        ' Varmistetaan, että käytetään vain yhtä aluetta
        If Hakutaulukko.Areas.Count > 1 Then
        MsgBox "Voit hakea vain yhtenäiseltä alueelta"
        Exit Function
        End If

        With Application

        'Jos hakuehtoa toiselle sarakkeele ei ole annettu,
        'niin palautetaan arvo vasemman puoleisesta sarakkeesta
        If HakuarvoSarake = -257 Then
        PHakuVasemmalle = _
        .Index(Hakutaulukko.Offset(0, PalArvoSarakeSiirtymä), _
        .Match(Hakuarvo, Hakutaulukko.Columns(1), 0), 1)

        ' Muuten palautetaan hakuarvoa vastaava arvo
        'syötetystä sarakkeesta -1
        Else
        PHakuVasemmalle = _
        .Index(Hakutaulukko.Offset(0, PalArvoSarakeSiirtymä), _
        .Match(Hakuarvo, Hakutaulukko.Columns(HakuarvoSarake), 0), 1)
        End If

        End With

        End Function


      • Kokeilunhaluinen
        Kunde kirjoitti:

        Mutta tällä voi hakea taulukosta kanssa mistä sarakkeesta tahansa :)

        Function PHakuVasemmalle(Hakuarvo, ByVal Hakutaulukko As Range, _
        PalArvoSarakeSiirtymä As Integer, _
        Optional HakuarvoSarake As Integer = -257)
        ' Tämä funktio hakee arvoja vasemmalta tai oikealta
        ' Kun määrittelet neljännen arvon voit käyttää mitä tahansa saraketta
        ' Kolmas argumentti on sarakkeiden määrä siirtymänä vasemmanpuoleisesta
        ' sarakkeesta (0 -pohjainen).Esim 1 palauttaa toisen sarakkeen arvon


        ' Varmistetaan, että käytetään vain yhtä aluetta
        If Hakutaulukko.Areas.Count > 1 Then
        MsgBox "Voit hakea vain yhtenäiseltä alueelta"
        Exit Function
        End If

        With Application

        'Jos hakuehtoa toiselle sarakkeele ei ole annettu,
        'niin palautetaan arvo vasemman puoleisesta sarakkeesta
        If HakuarvoSarake = -257 Then
        PHakuVasemmalle = _
        .Index(Hakutaulukko.Offset(0, PalArvoSarakeSiirtymä), _
        .Match(Hakuarvo, Hakutaulukko.Columns(1), 0), 1)

        ' Muuten palautetaan hakuarvoa vastaava arvo
        'syötetystä sarakkeesta -1
        Else
        PHakuVasemmalle = _
        .Index(Hakutaulukko.Offset(0, PalArvoSarakeSiirtymä), _
        .Match(Hakuarvo, Hakutaulukko.Columns(HakuarvoSarake), 0), 1)
        End If

        End With

        End Function

        Vääntäisitkö rautalangasta miten tuota käytetään.


      • Kunde
        Kokeilunhaluinen kirjoitti:

        Vääntäisitkö rautalangasta miten tuota käytetään.

        Lisää VBa editorissa moduuli ja kopioi koodi sinne.Tee soluun kaava lisää funktiolla PhakuVasemmalle ja anna argumentit seuraavasti.
        1. Tapaus haetaan arvo mistä sarakkeesta tahansa

        Hakuarvo=Arvo millä haetaan
        Hakutaulukko=Alue mistä haetaan
        PalArvoSarakeSiirtymä=Hakutaulukon sarakkeen numero vasemmalta alkaen ,jonka arvo halutaan palauttaa (hakutaulukon vasemmanpuoleisin sarake=0).
        HakuarvoSarake= sarakkeen numero hakutaulukossa (vasemmanpuoleisin sarake=1)
        jos HakuarvoSaraketta ei määritellä toimii kuten normaali PHAKU, mutta muista muuttaa Hakutaulukko myös vastaamaan normaalia PHAKU taulukkoa elikkä hakuehto on hakualueen vasemmanpuoleisin sarakkeessa...
        tulikohan se nyt selvästi kerrottua?
        esim.
        solussa on kaava
        =PHakuVasemmalle(H1;A1:F13;2;6)
        H1= arvo millä haetaan
        A1:F13= hakualue
        2= sarake mistä arvo palautetaan -vasemmanpuoleisin sarake on 0 jne.
        6= sarake missä haettava arvo on -vasemmanpuoleisin sarake on 1

        2. Tapaus neljättä argumenttiä ei anneta,siis normaali PHAKU tapaus
        Hakuarvo=Arvo millä haetaan
        Hakutaulukko=Alue mistä haetaan, nyt pitää muistaa,että Hakuarvo pitää olla alueen vasemmanpuoleisessa sarakkeessa
        PalArvoSarakeSiirtymä=Hakutaulukon sarakkeen numero vasemmalta alkaen ,jonka arvo halutaan palauttaa (hakutaulukon vasemmanpuoleisin sarake=0).
        HakuarvoSarake= tämä jätetään nyt tyhjäksi!
        esim.
        solussa on kaava
        =PHakuVasemmalle(H3;C1:F13;1)
        H3= arvo millä haetaan
        C1:F13= hakualue
        1= sarake mistä arvo palautetaan -vasemmanpuoleisin sarake on 0 jne.

        Mallitiedosto kertoisi enemmän kuin 1000 sanaa ... mutta tässä foorumissa sitä ei voi liittää mukaan.


      • Kokeilunhaluinen
        Kunde kirjoitti:

        Lisää VBa editorissa moduuli ja kopioi koodi sinne.Tee soluun kaava lisää funktiolla PhakuVasemmalle ja anna argumentit seuraavasti.
        1. Tapaus haetaan arvo mistä sarakkeesta tahansa

        Hakuarvo=Arvo millä haetaan
        Hakutaulukko=Alue mistä haetaan
        PalArvoSarakeSiirtymä=Hakutaulukon sarakkeen numero vasemmalta alkaen ,jonka arvo halutaan palauttaa (hakutaulukon vasemmanpuoleisin sarake=0).
        HakuarvoSarake= sarakkeen numero hakutaulukossa (vasemmanpuoleisin sarake=1)
        jos HakuarvoSaraketta ei määritellä toimii kuten normaali PHAKU, mutta muista muuttaa Hakutaulukko myös vastaamaan normaalia PHAKU taulukkoa elikkä hakuehto on hakualueen vasemmanpuoleisin sarakkeessa...
        tulikohan se nyt selvästi kerrottua?
        esim.
        solussa on kaava
        =PHakuVasemmalle(H1;A1:F13;2;6)
        H1= arvo millä haetaan
        A1:F13= hakualue
        2= sarake mistä arvo palautetaan -vasemmanpuoleisin sarake on 0 jne.
        6= sarake missä haettava arvo on -vasemmanpuoleisin sarake on 1

        2. Tapaus neljättä argumenttiä ei anneta,siis normaali PHAKU tapaus
        Hakuarvo=Arvo millä haetaan
        Hakutaulukko=Alue mistä haetaan, nyt pitää muistaa,että Hakuarvo pitää olla alueen vasemmanpuoleisessa sarakkeessa
        PalArvoSarakeSiirtymä=Hakutaulukon sarakkeen numero vasemmalta alkaen ,jonka arvo halutaan palauttaa (hakutaulukon vasemmanpuoleisin sarake=0).
        HakuarvoSarake= tämä jätetään nyt tyhjäksi!
        esim.
        solussa on kaava
        =PHakuVasemmalle(H3;C1:F13;1)
        H3= arvo millä haetaan
        C1:F13= hakualue
        1= sarake mistä arvo palautetaan -vasemmanpuoleisin sarake on 0 jne.

        Mallitiedosto kertoisi enemmän kuin 1000 sanaa ... mutta tässä foorumissa sitä ei voi liittää mukaan.

        Ohjeet oli niin hyvät, että minäkin sain sen toimimaan pikku haparoinnin jälkeen.


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

    Luetuimmat keskustelut

    1. Mitä tahtuu Kasperi Viita/Suviviita

      Poliisia ja ambulanssia iso määrä.
      Seinäjoki
      87
      3587
    2. Kalasataman talossa lienee rakennusvirhe

      Ei pitäisi olla mahdollista parvekkeen kautta tulipalon kiivetä katolle saakka kuin korkeintaan ylimmästä kerroksesta.
      Maailman menoa
      187
      1423
    3. Mikä on kaivattusi

      ammatti?
      Ikävä
      77
      1387
    4. Kristillinen Kaste on syntisten kaste, ei itsensä uskoviksi julistaneiden kaste

      Raamatun mukaan vain syntisyyden vuoksi kastetut saavat kasteen hyödyn, syntien anteeksisaamisen ja Pyhän Hengen lahjan
      Kaste
      240
      1070
    5. Kaipaatko nainen

      Semmoista tosi hankalaa ja arkaa miestä? Pitäisitkö hänet aina omanasi jos saisit hänet? Miten huomioisit hänen herkkyyd
      Ikävä
      105
      1010
    6. Venäjä teki mahtavan iskun Kiovaan?

      Miksi Ukraina ei kykene tekemään Moskovaan yhtä mahtavia iskuja.
      Maailman menoa
      309
      974
    7. Onko kaivattusi ulkonäkö

      tarpeeksi miellyttävä? 🥕
      Ikävä
      45
      897
    8. Mökille pariksi viikoksi hänen kanssaan

      Ei teknologialaitteita. Niin ❤️
      Ikävä
      95
      867
    9. Milloin ymmärsit

      Milloin tunnistit, että sinulle kirjoitetaan ja kuka kirjoittaa? Tarkka päivämäärä ja kellonaika 😉 Önnönnöö, jos ei os
      Ikävä
      77
      862
    10. Nojatuoli !

      Uutta kehiin, kun edellinen pikavauhtia täyttyi, pitäisikö kiittää näitä asian jouduttaneita? Pilvet leijaa, sadetta en
      80 plus
      124
      845
    Aihe