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

298

    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. Kelekkakisat

      Mikä vakava onnettomuus sattunut kisoissa. On peruttu koko kisat. Pelastuskopteri näytti käyvän paikalla.
      Nivala
      24
      10965
    2. Aivan kauheaa

      Veikö koskiuoma taas ihmishengen? Se pitää kieltää!
      Imatra
      41
      8248
    3. Onko kaivattusi

      …mielestäsi älykäs, tai kenties tyhmä? Oma mielipide.
      Ikävä
      126
      5267
    4. Kuinka pitkä välimatka

      on teidän kotien välillä?
      Ikävä
      143
      3646
    5. Epäilen ettet edes

      Kehtaisi liikkua kanssani.
      Ikävä
      69
      3578
    6. Virkamiehille tarvitaan tuntuvat palkankorotukset

      Naistenpäivänä on syytä muistuttaa, että virkamiehen euro on vain 80 senttiä. Palkat tulee saattaa samalle tasolle yksi
      Maailman menoa
      35
      3524
    7. Oletko huomannut

      Yhden muutoksen?
      Ikävä
      33
      3157
    8. Jäikö meidän välit

      Mielestäsi Kesken?
      Ikävä
      55
      2529
    9. Olisipa saanut sinuun

      Tutustua paremmin. Harmi että aloin lopulta jännittämään kun näytit tunteesi niin voimakkaasti ja lähestyit niin voimaak
      Ikävä
      35
      2021
    10. Miltä mahtaa tuntua

      Sitten kun näet hänet pitkästä aikaa?
      Tunteet
      28
      1786
    Aihe