Přejít k hlavnímu obsahu

Jak automaticky skrýt sloupce podle data v aplikaci Excel?

Předpokládejme, že mám v listu řadu dat, teď chci automaticky skrýt sloupce na základě konkrétního data. Například když zadám datum 5/16/2016 do buňky, chci okamžitě skrýt sloupce, jejichž datum je menší než toto konkrétní datum, jak ukazuje následující snímek obrazovky. Tento článek představí některé triky pro jeho řešení.

doc skrýt sloupce podle data 1

Automaticky skryjte sloupce na základě konkrétního data pomocí kódu VBA

Skrýt sloupce na základě konkrétního data pomocí Kutools pro Excel


šipka modrá pravá bublina Automaticky skryjte sloupce na základě konkrétního data pomocí kódu VBA

K dokončení tohoto úkolu vám může pomoci následující kód VBA, postupujte takto:

1. Vyberte kartu listu, kterou chcete skrýt podle data, a klikněte pravým tlačítkem a vyberte ji Zobrazit kód z kontextového menu přejděte do Microsoft Visual Basic pro aplikace okno a poté zkopírujte a vložte následující kód do modulu:

Kód VBA: Automaticky skrýt sloupce na základě konkrétního data:

Private Sub Worksheet_Change(ByVal Target As Range)
'Updateby Extendoffice
    Dim xCell As Range
    If Target.Address <> Range("K4").Address Then Exit Sub
    Application.ScreenUpdating = False
    For Each xCell In Range("A1:I1")
        xCell.EntireColumn.Hidden = (xCell.Value < Target.Value)
    Next
    Application.ScreenUpdating = True
End Sub

doc skrýt sloupce podle data 2

2. Poté tento kód uložte a zavřete, vraťte se do listu a nyní, když zadáte datum do buňky K4, sloupce, jejichž datum je menší než toto konkrétní datum, budou automaticky skryty.

Poznámka: Ve výše uvedeném kódu, K4 je konkrétní buňka data, na které chcete skrýt sloupce, A1: I1 je řádek buňky obsahují datum, které jste použili.


šipka modrá pravá bublina Skrýt sloupce na základě konkrétního data pomocí Kutools pro Excel

Pokud nejste obeznámeni s kódem, zde je praktický nástroj -Kutools pro Excel, S jeho Vyberte konkrétní buňky nástroj, můžete tuto práci snadno dokončit.

Kutools pro Excel : s více než 300 praktickými doplňky Excel, můžete si je vyzkoušet bez omezení do 30 dnů. 

Po instalaci Kutools pro Excel, postupujte následovně:

1. Vyberte záhlaví data a klikněte na Kutools > vybrat > Vyberte konkrétní buňky, viz screenshot:

2. Ve vyskočené Vyberte konkrétní buňky dialogové okno vyberte Celý sloupec z Typ výběrua poté vyberte kritéria, například Méně než z Specifický typ rozevírací seznam a zadejte datum do dalšího textového pole, na kterém chcete skrýt sloupce, viz screenshot:

doc skrýt sloupce podle data 4

3. A pak klikněte na tlačítko Ok tlačítko, najednou jsou vybrány konkrétní sloupce, jejichž datum je menší než 5/16/2016, viz screenshot:

doc skrýt sloupce podle data 5

4. Poté klikněte pravým tlačítkem na libovolné vybrané záhlaví sloupce a vyberte Skrýt skrýt tyto vybrané sloupce podle potřeby. Viz snímek obrazovky:

doc skrýt sloupce podle data 6

Klikněte na Stažení zdarma Kutools pro Excel hned teď!

Nejlepší nástroje pro produktivitu v kanceláři

🤖 Kutools AI asistent: Revoluční analýza dat založená na: Inteligentní provedení   |  Generovat kód  |  Vytvořte vlastní vzorce  |  Analyzujte data a generujte grafy  |  Vyvolejte funkce Kutools...
Populární funkce: Najít, zvýraznit nebo identifikovat duplikáty   |  Odstranit prázdné řádky   |  Kombinujte sloupce nebo buňky bez ztráty dat   |   Kolo bez vzorce ...
Super vyhledávání: Více kritérií VLookup    VLookup s více hodnotami  |   VLookup na více listech   |   Fuzzy vyhledávání ....
Pokročilý rozevírací seznam: Rychle vytvořte rozevírací seznam   |  Závislý rozbalovací seznam   |  Vícenásobný výběr rozevíracího seznamu ....
Správce sloupců: Přidejte konkrétní počet sloupců  |  Přesunout sloupce  |  Přepnout stav viditelnosti skrytých sloupců  |  Porovnejte rozsahy a sloupce ...
Doporučené funkce: Zaměření mřížky   |  Návrhové zobrazení   |   Velký Formula Bar    Správce sešitů a listů   |  Knihovna zdrojů (Automatický text)   |  Výběr data   |  Zkombinujte pracovní listy   |  Šifrovat/dešifrovat buňky    Odesílat e-maily podle seznamu   |  Super filtr   |   Speciální filtr (filtr tučné/kurzíva/přeškrtnuté...) ...
Top 15 sad nástrojů12 Text Tools (doplnit text, Odebrat znaky, ...)   |   50+ Graf Typ nemovitosti (Ganttův diagram, ...)   |   40+ Praktické Vzorce (Vypočítejte věk na základě narozenin, ...)   |   19 Vložení Tools (Vložte QR kód, Vložit obrázek z cesty, ...)   |   12 Konverze Tools (Čísla na slova, Přepočet měny, ...)   |   7 Sloučit a rozdělit Tools (Pokročilé kombinování řádků, Rozdělit buňky, ...)   |   ... a více

Rozšiřte své dovednosti Excel pomocí Kutools pro Excel a zažijte efektivitu jako nikdy předtím. Kutools for Excel nabízí více než 300 pokročilých funkcí pro zvýšení produktivity a úsporu času.  Kliknutím sem získáte funkci, kterou nejvíce potřebujete...

Popis


Office Tab přináší do Office rozhraní s kartami a usnadňuje vám práci

  • Povolte úpravy a čtení na kartách ve Wordu, Excelu, PowerPointu, Publisher, Access, Visio a Project.
  • Otevřete a vytvořte více dokumentů na nových kartách ve stejném okně, nikoli v nových oknech.
  • Zvyšuje vaši produktivitu o 50%a snižuje stovky kliknutí myší každý den!
Comments (2)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
I have the same issue as Chris. The cell with my date does not always change. I need the macro to run regardless of whether the date has changed from last month or is the same as last month without having to click on the cell itself and hit enter to trigger the "Change"
This comment was minimized by the moderator on the site
Hello,
Thanks for the code.
In my case the cell K4 is a calculation cell from the formula =EOMONTH(A1,0). Example: A1 = 01.03.2017. K4 takes the value 31.03.2017. But the VBA code that you propose does not hide the columns until I click on K4 cell and press Enter to refresh it. I tried to add Range("K4").calculate but with no effect. Help please.
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations