Apua, liittyen pikasuodatukseen ja kaavoihin!!!

Apua tarvitseva

Minulla on taulukko, jossa on sarakkeessa H useita kirjainnumero yhdistelmiä sekä myös tyhjiä kenttiä. Suodatan tuon sarakkeen perusteella tietoja. Haluaisin näyttää h-sarakkeeseen jääneiden arvojen tiedon toisessa solussa. Dget-funktio on varmaankin tähän oivallinen tapa, mutta se ei osaa ottaa huomioon suodatusta vaan näyttää, että sarakkeessa on samoja arvoja. Yritin yhdistää tuota subtotalin kanssa, mutta en osannut tehdä sitä oikein. Olisin kovin kiitollinen avusta! Haluan päästä tässä hommassa eteenpäin.

10

477

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Apua tarvitseva

      tai tarkoitin siis, että dget-funktio ilmoittaa, että sarakkeessa on eri arvoja...jeesatkaa onnetonta Excelin käyttäjää

    • 45454454544444

      No, kai sinä sen osaat tehdä. Ja pikasuodatuksen tuloksen voi "tallentaa" omaksi mukautetuksi näkymäksi - eli kun on suodatuksen tulos siinä esillä, niin sitten Näytä Mukautetut näkymät ja siellä Lisää ja nimeä tämä suodatuksen tulos ja ok. Silloin se tulos löytyy sieltä mukautetuista myöhemmin.

      • Apua tarvitseva

        huonosti oon selittäny tuon... eli ei nuo tyhjät kentät mitään haittaa. (en tiedä, miksi sen olen tuohon edes kirjoittanut, varmaan ainainen kiire prkl). Enkä halua tallentaa kutakin suodatuksen jälkeistä näkymää.

        Koitan kertoa tilanteen vähän selvemmin. Tilanne on kuitenkin yksinkertainen. Minulla on sarakkeessa arvoja esim. yy12,yy12,yy12,tt13, er99 jne. Suodatuksen jälkeen näkyviin jää esimerkiksi arvot yy12. Kuinka saan tuon arvon näkyviin uuteen soluun esim d18 samalla välilehdellä. Entäs jos suodatan uudelleen? Tarviiko tähän peräti jotain skriptiä kirjottaa vai onko tähän joku välisumman tapainen ratkaisu olemassa, mikä osaa ottaa huomioon tuon suodatuksen. Vai ajattelenko asioita vähän liian vaikeasti.


      • Apua tarvitseva kirjoitti:

        huonosti oon selittäny tuon... eli ei nuo tyhjät kentät mitään haittaa. (en tiedä, miksi sen olen tuohon edes kirjoittanut, varmaan ainainen kiire prkl). Enkä halua tallentaa kutakin suodatuksen jälkeistä näkymää.

        Koitan kertoa tilanteen vähän selvemmin. Tilanne on kuitenkin yksinkertainen. Minulla on sarakkeessa arvoja esim. yy12,yy12,yy12,tt13, er99 jne. Suodatuksen jälkeen näkyviin jää esimerkiksi arvot yy12. Kuinka saan tuon arvon näkyviin uuteen soluun esim d18 samalla välilehdellä. Entäs jos suodatan uudelleen? Tarviiko tähän peräti jotain skriptiä kirjottaa vai onko tähän joku välisumman tapainen ratkaisu olemassa, mikä osaa ottaa huomioon tuon suodatuksen. Vai ajattelenko asioita vähän liian vaikeasti.

        ei tuo onnaa ilman koodia...
        D18 soluun kaava esim. jos haluamasi sarakkeen suodatusehtovalikko on solussa C2 =Pikasuodatus(C2)
        näyttää myös ja/tai ehdotkin ja jos ei ole mitään suodatusta niin KAIKKI teksti soluun D18...

        moduuliin...

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = .Criteria1
        Select Case .Operator
        Case xlAnd
        Suodatin = Suodatin & " JA " & .Criteria2
        Case xlOr
        Suodatin = Suodatin & " TAI " & .Criteria2
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Suodatin
        End Function

        Keep EXCELing
        @Kunde


      • kunde kirjoitti:

        ei tuo onnaa ilman koodia...
        D18 soluun kaava esim. jos haluamasi sarakkeen suodatusehtovalikko on solussa C2 =Pikasuodatus(C2)
        näyttää myös ja/tai ehdotkin ja jos ei ole mitään suodatusta niin KAIKKI teksti soluun D18...

        moduuliin...

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = .Criteria1
        Select Case .Operator
        Case xlAnd
        Suodatin = Suodatin & " JA " & .Criteria2
        Case xlOr
        Suodatin = Suodatin & " TAI " & .Criteria2
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Suodatin
        End Function

        Keep EXCELing
        @Kunde

        toki tolla kaavalla saa muittenkin sarakkeiden suodatusehdot esille esim. viitaten edelliseen postaukseeni =Pikasuodatus(B2) näyttää sarakkeem B suodatusehdot....

        Keep EXCELing
        @Kunde


      • Apua tarvitseva
        kunde kirjoitti:

        toki tolla kaavalla saa muittenkin sarakkeiden suodatusehdot esille esim. viitaten edelliseen postaukseeni =Pikasuodatus(B2) näyttää sarakkeem B suodatusehdot....

        Keep EXCELing
        @Kunde

        Kiitoksia kovasti, olet ollut suuri apu niin minulle kuin monelle muullekin täällä keskusteluissa pyöriville.Kaavasi toimii ja sain sen jopa räplättyä käymään yhteen oman avuttoman skriptini kanssa, mitä kuitenkin tarvitsen osana laskentataulukokkoa.

        Osaatko vielä sanoa, mitä minun täytyy tehdä, että saan tuon =merkin pois näkyvistä solusta, johon tieto on tuotu. Myös välilyönnin kohdalle tulevat aaltoviivat ~ eivät ole toivottuja. Saako niitä poistettua? (esim d18 solun näkymä. =yy12 tai =yy12~)


      • Apua tarvitseva kirjoitti:

        Kiitoksia kovasti, olet ollut suuri apu niin minulle kuin monelle muullekin täällä keskusteluissa pyöriville.Kaavasi toimii ja sain sen jopa räplättyä käymään yhteen oman avuttoman skriptini kanssa, mitä kuitenkin tarvitsen osana laskentataulukokkoa.

        Osaatko vielä sanoa, mitä minun täytyy tehdä, että saan tuon =merkin pois näkyvistä solusta, johon tieto on tuotu. Myös välilyönnin kohdalle tulevat aaltoviivat ~ eivät ole toivottuja. Saako niitä poistettua? (esim d18 solun näkymä. =yy12 tai =yy12~)

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = Mid(.Criteria1, 2)
        Select Case .Operator
        Case xlAnd
        Suodatin = Mid(Suodatin & " JA " & .Criteria2, 2)
        Case xlOr
        Suodatin = Mid(Suodatin & " TAI " & .Criteria2, 2)
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Suodatin
        End Function

        "Myös välilyönnin kohdalle tulevat aaltoviivat ~ eivät ole toivottuja. Saako niitä poistettua? (esim d18 solun näkymä. =yy12 tai =yy12~)"

        nuo ~- merkit on soluissa (ei kylläkään välilyöti...) voit ne poistaa lisäämällä koodiin replace funktion millä korvaat ~- merkit välilyönneiksi
        esim. Replace(Suodatin, "~", " ")

        Keep EXCELing
        @Kunde


      • Apua tarvitseva
        kunde kirjoitti:

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = Mid(.Criteria1, 2)
        Select Case .Operator
        Case xlAnd
        Suodatin = Mid(Suodatin & " JA " & .Criteria2, 2)
        Case xlOr
        Suodatin = Mid(Suodatin & " TAI " & .Criteria2, 2)
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Suodatin
        End Function

        "Myös välilyönnin kohdalle tulevat aaltoviivat ~ eivät ole toivottuja. Saako niitä poistettua? (esim d18 solun näkymä. =yy12 tai =yy12~)"

        nuo ~- merkit on soluissa (ei kylläkään välilyöti...) voit ne poistaa lisäämällä koodiin replace funktion millä korvaat ~- merkit välilyönneiksi
        esim. Replace(Suodatin, "~", " ")

        Keep EXCELing
        @Kunde

        Saako tuon replacen sohlattua tuohon sinun koodiisi jotenkin vai miten se oli tarkoitus tehdä? Voiko siinä käyttää näitä If then juttuja. Oon aika tunari näissä koodi hommissa, olet varmaan huomannut =).


      • Apua tarvitseva kirjoitti:

        Saako tuon replacen sohlattua tuohon sinun koodiisi jotenkin vai miten se oli tarkoitus tehdä? Voiko siinä käyttää näitä If then juttuja. Oon aika tunari näissä koodi hommissa, olet varmaan huomannut =).

        "nuo ~- merkit on soluissa (ei kylläkään välilyöti...) voit ne poistaa lisäämällä koodiin replace funktion millä korvaat ~- merkit välilyönneiksi
        esim. Replace(Suodatin, "~", " ")"

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = Mid(.Criteria1, 2)
        Select Case .Operator
        Case xlAnd
        Suodatin = Mid(Suodatin & " JA " & .Criteria2, 2)
        Case xlOr
        Suodatin = Mid(Suodatin & " TAI " & .Criteria2, 2)
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Replace(Suodatin, "~", " ")
        End Function

        Keep EXCELing
        @Kunde


      • Apua tarvitseva
        kunde kirjoitti:

        "nuo ~- merkit on soluissa (ei kylläkään välilyöti...) voit ne poistaa lisäämällä koodiin replace funktion millä korvaat ~- merkit välilyönneiksi
        esim. Replace(Suodatin, "~", " ")"

        Function Pikasuodatus(Alue As Range) As String
        Dim Suodatin As String
        Suodatin = ""
        On Error GoTo Poistu
        Application.Volatile True
        With Alue.Parent.AutoFilter
        If Not Intersect(Alue, .Range) Is Nothing Then
        With .Filters(Alue.Column - .Range.Column 1)
        If .On Then
        Suodatin = Mid(.Criteria1, 2)
        Select Case .Operator
        Case xlAnd
        Suodatin = Mid(Suodatin & " JA " & .Criteria2, 2)
        Case xlOr
        Suodatin = Mid(Suodatin & " TAI " & .Criteria2, 2)
        End Select

        Else
        Suodatin = "KAIKKI"
        End If
        End With
        End If
        End With
        Poistu:
        Pikasuodatus = Replace(Suodatin, "~", " ")
        End Function

        Keep EXCELing
        @Kunde

        Olet mainio tyyppi koodia vääntämään. Palataan myöhemmin asiaan, jos tulee ongelmia... siis aivan kohta =D


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

    Luetuimmat keskustelut

    1. Turussa Varissuolla bussikuski ajoi lapsen yli lapsi kuoli

      Poliisi " Epäilee " kuskia törkeästä liikenneturvallisuuden vaarantamisesta ja törkeästä kuolemantuottamuksesta.
      Maailman menoa
      339
      1976
    2. IS: Väitöstutkimus - Pyöräilybuumi oli pelkkä kupla!

      Pyöräilybuumista paljastui karu totuus Väitöstutkimuksen mukaan suuri suomalainen pyöräilyrenessanssi olikin vain pelkk
      Maailman menoa
      47
      1629
    3. Milloin bikineistä

      Tuli juhla tai esiintymis asu? Pikkasen harkintaa vois käyttää. Bikinit kuuluvat uimarannalle. No, mitä maailman tähdet
      Maailman menoa
      154
      1311
    4. 143
      1158
    5. Apostolit kastoivat eri tavalla kuin kirkko

      Raamatussa on kaksi ristiriitaista kastekaavaa. Toinen ei voi olla oikea. Kumpi on alkuperäinen? "Menkää siis ja tehkää
      Kaste
      502
      1151
    6. Johanna Tukiainen ei suostu muuttamaan pois vuokra-asunnosta!

      Seiska kertoi tänään, että Johanna Tukiainen ei ole suostunut poistumaan Helsingin Munkkisaarenkadun vuokra-asunnostaan.
      Kotimaiset julkkisjuorut
      84
      1141
    7. Mene perheinesi arkkiin - kasteelle !

      Juutalaiset oli hyvin lapsirakkaita, mitään ehkäisyä ei käytetty. Perheissä oli paljon lapsia. Viiden koko perheen kast
      Kaste
      470
      1057
    8. Olimmeko molemmat

      ujoja ja hankalia, vai minä vain? Mietin, oliko se silloin epävarmuutta vai kiinnostuksen puutetta.
      Ikävä
      79
      1042
    9. Mun on ikävä sua J ,

      Mun on ikävä sua J, haluaisin tutustua paremmin (vaikka tämä aivan älytöntä onkin). Voitaisiinko nähdä ja jutella ihan
      Ikävä
      48
      962
    10. Martina Aitolehden Victoria-tytär, 16, tietää riskit - Teki silti yllättävän päätöksen

      Victoria Eerikäinen on Martina Aitolehden ja Esko Eerikäisen tytär. Hän on yksi Nepot-sarjan tähdistä. Sarjan kuvausten
      Suomalaiset julkkikset
      9
      948
    Aihe