Autofilter Field kohtaan kaava

yks.kysymys

Moi.
Minulla on 1 rivillä päivämääriä, ja sen alla soluja eri väreillä.

Miten saan napin autofiltertoiminnon toimimaan siten että se suodattaa tämän päivän kohdan tietyllä värillä olevat rivit?

Sain sillä tavalla toimimaan että sarakenumero on tietty (Field:=8)
Miten saan sen että nappi valitsee tämän päivän kohdalta sarakkeen (esim. AA1) ja suodattaa siitä punaisella värillä olevat solut (eli Field: ( tilalle AA1 vaastaava sarake tänään, huomenna AB1 sarake, jne

Private Sub ToggleButton1_Click()

If ToggleButton1.Value = True Then
On Error Resume Next
ActiveSheet.Range("$A$8:$CDZ$95").AutoFilter Field:=8, Criteria1:=RGB(255, 0 _
, 0), Operator:=xlFilterCellColor


Else
On Error Resume Next
ActiveSheet.Shapes.Range(Array("ToggleButton1")).Select
ActiveSheet.Range("$A$8:$CDZ$95").AutoFilter Field:=8

End If
End Sub

6

286

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • automaatisesti löydät sarakkeen VBA:ssa
      Application.WorksheetFunction.Match(cdbl(Date), Range("8:8"))

      Keep EXCEling
      @Kunde

    • yks.kysymys

      Kyseessä on siis aikataulu, jossa eri tapahtumien soluja eri väreillä
      Siis päivämäärät ovat rivillä 1
      tapahtumat ovat alla olevilla riveillä vuoden ajalta, eli sarakkeet B:NB

      Tarkoitin sellaista toimintoa että nappia alas painamalla näkyisi vain tämän päivän kohdalla vaikkapa punaisella värillä merkityt tapahtumat, eli valitaan sarakke tämän päivän kohdalta, ja siitä sarakkeesta suodatetaan punaiset solut eri riveiltä.

      Sain tehtyä napin joka hakee tämän päivän mutta että samalla napilla vielä samalla suodattaisi värin mukaan...

    • jos antamasi kaava toimii niin kuten sanoin postauksessani löydät oikean sarakkeen ko päivänä
      Application.WorksheetFunction.Match(cdbl(Date), Range("8:8"))...

      lisättynä toimivaan koodiisi

      Private Sub ToggleButton1_Click()
      On Error Resume Next
      If ToggleButton1.Value = True Then

      ActiveSheet.Range("$A$8:$CDZ$95").AutoFilter Field:=Application.WorksheetFunction.Match(CDbl(Date), Range("1:1")), Criteria1:=RGB(255, 0 _
      , 0), Operator:=xlFilterCellColor

      Else

      ActiveSheet.Shapes.Range(Array("ToggleButton1")).Select
      ActiveSheet.Range("$A$8:$CDZ$95").AutoFilter Field:=Application.WorksheetFunction.Match(CDbl(Date), Range("1:1"))

      End If
      End Sub

      Keep EXCEling
      @Kunde

      • yks.kysymys

        Kiitos.
        Saisiko vielä suodatusta niin että se valitsisi kaikki muut värit paitsi valkoisen.
        En saanut erisuuri merkkiä (<>) toimimaan = merkin tilalla


      • yks.kysymys

        Tällainen koodi ei siis toimi:
        Criteria1:<>RGB(255, 255, 255), Operator:=xlFilterCellColor

        Mikä toimisi jotta suodattaisi muut paitsi valkoiset?


    • Kundepuu

      väreillä hiukan vaikeempaa, mutta lisäämällä apusarakkeen ja siihen koodaamalla värikoodit ja arvojen perusteella voi sitten suodattaa(-4142 on ei täyttöä ja värit sitten positiivisiä) , eli nyt lisäsin CEA sarakkeen suodatusalueeseen ja sitä hyödynsin... ;-)
      muuta tarvittaessa sarake koodiin
      sarake CAE on Field:=2159


      Private Sub ToggleButton1_Click()
      Dim Sarake As Long
      Dim i As Long

      On Error Resume Next
      If ToggleButton1.Value = True Then
      Range("CEA:CEA") = ""
      Sarake = Application.WorksheetFunction.Match(CDbl(Date), Range("1:1"))
      For i = 9 To 95
      Range("CEA" & i) = Cells(i, Sarake).Interior.ColorIndex

      Next
      ActiveSheet.Range("$A$8:$CEA$95").AutoFilter Field:=2159, Criteria1:=">0"

      Else

      ActiveSheet.Shapes.Range(Array("ToggleButton1")).Select
      ActiveSheet.Range("$A$8:$CEA$95").AutoFilter Field:=Sarake
      End If
      End Sub

      Keep EXCEling
      @Kunde

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

    Luetuimmat keskustelut

    1. Kaivatullesi viesti ensi vuoteen?

      Kerro meneekö naiselle vai miehelle ja vähintään yksi tunniste, esim. kirjain.
      Ikävä
      148
      6941
    2. Yritystuet pois ja työeläkevaroilla maksettava valtion velka pois

      Nyt on teille kerrottu keino kuinka Suomen velkaongelmasta päästää eroon kertalaakista. Älkää saatanat enää minulle tul
      Maailman menoa
      36
      3885
    3. Nyt Yle otti silmätikukseen sisäministeri Rantasen

      Aivan erinomaista työtä tehnyt sisäministeri Mari Rantanen on saanut paljon aikaiseksi. Maahanmuuttoon ja maahanmuuttaji
      Maailman menoa
      310
      3276
    4. Ylen juttu sisäministeristä oli selvän tarkoitushakuinen

      haluttiin vielä vuoden loppuun saada joku "kohu". (Olisiko Yle tehnyt jutun jos sisäministerinä olisi esim. RKP:n, jota
      Maailman menoa
      71
      2852
    5. Suomalaista yrittäjää ei kommunistista erota

      Muualla maailmassa yrittäjät elävät asiakkaiden rahoilla, Suomessa palkansaajien maksamilla veroilla. Palkansaajahan ma
      Maailman menoa
      8
      2317
    6. Milloin näit kaivattusi edellisen kerran?

      Olitteko juttusilla vai sivusta vain? Miten reagoit?
      Ikävä
      21
      1893
    7. Liikaa vauhtia

      Nuorukainen 17v. on ajanut 114 km/h 60 km:n alueella Nesteen kohdalla ja onneksi poliisi oli paikalla ja hurjastelu lopp
      Suomussalmi
      48
      1765
    8. 15
      1686
    9. Ulkoministeriön konsulipäällikkö arvostelee rajusti Haavistoa: "Täällä on pelon ilmapiiri"

      "– Täällä on ministerin toimien takia aivan selvästi pelon ilmapiiri. Jos sellaisen annetaan pesiytyä virkamieskulttuuri
      Maailman menoa
      5
      1644
    10. 72
      1470
    Aihe