Bỏ qua nội dung chính

Làm cách nào để tự động ẩn các cột dựa trên ngày tháng trong Excel?

Giả sử, tôi có một phạm vi dữ liệu trong một trang tính, bây giờ, tôi muốn tự động ẩn các cột dựa trên một ngày cụ thể. Ví dụ: khi tôi nhập ngày 5/16/2016 vào một ô, tôi muốn ẩn các cột có ngày nhỏ hơn ngày cụ thể này ngay lập tức như ảnh chụp màn hình sau. Bài viết này sẽ giới thiệu một số thủ thuật để giải quyết nó.

doc ẩn các cột theo ngày 1

Tự động ẩn các cột dựa trên một ngày cụ thể với mã VBA

Ẩn các cột dựa trên một ngày cụ thể với Kutools cho Excel


mũi tên màu xanh bong bóng bên phải Tự động ẩn các cột dựa trên một ngày cụ thể với mã VBA

Để hoàn thành tác vụ này, mã VBA sau có thể giúp bạn, vui lòng thực hiện như sau:

1. Chọn tab trang tính mà bạn muốn ẩn theo ngày và nhấp chuột phải để chọn Mã Chế độ xem từ menu ngữ cảnh để chuyển đến Microsoft Visual Basic cho các ứng dụng cửa sổ, sau đó sao chép và dán mã sau vào Mô-đun:

Mã VBA: Tự động ẩn các cột dựa trên ngày cụ thể:

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 ẩn các cột theo ngày 2

2. Sau đó, lưu và đóng mã này, quay lại trang tính và bây giờ, khi bạn nhập ngày vào ô K4, các cột có ngày nhỏ hơn ngày cụ thể này sẽ tự động bị ẩn.

Chú thích: Trong đoạn mã trên, K4 là ô ngày cụ thể mà bạn muốn ẩn các cột dựa trên, A1: I1 là các ô hàng chứa ngày bạn đã sử dụng.


mũi tên màu xanh bong bóng bên phải Ẩn các cột dựa trên một ngày cụ thể với Kutools cho Excel

Nếu bạn không quen thuộc với mã, đây là một công cụ hữu ích-Kutools cho Excel, Với khả Chọn các ô cụ thể tiện ích, bạn có thể hoàn thành công việc này một cách dễ dàng.

Kutools cho Excel : với hơn 300 bổ trợ Excel tiện dụng, dùng thử miễn phí không giới hạn trong 30 ngày. 

Sau khi cài đặt Kutools cho Excel, vui lòng làm như sau:

1. Chọn tiêu đề ngày và nhấp vào Kutools > Chọn > Chọn các ô cụ thể, xem ảnh chụp màn hình:

2. Trong cửa sổ bật ra Chọn các ô cụ thể hộp thoại, chọn Toàn bộ cột từ Loại lựa chọnrồi chọn các tiêu chí, chẳng hạn như Ít hơn từ Loại cụ thể danh sách thả xuống và nhập ngày vào hộp văn bản bên cạnh mà bạn muốn ẩn các cột dựa trên, xem ảnh chụp màn hình:

doc ẩn các cột theo ngày 4

3. Và sau đó nhấp vào Ok , các cột cụ thể có ngày dưới 5/16/2016 được chọn cùng một lúc, xem ảnh chụp màn hình:

doc ẩn các cột theo ngày 5

4. Sau đó, nhấp chuột phải vào bất kỳ một tiêu đề cột đã chọn nào và chọn Ẩn giấu để ẩn các cột đã chọn của luận án khi bạn cần. Xem ảnh chụp màn hình:

doc ẩn các cột theo ngày 6

Nhấp vào Tải xuống miễn phí Kutools cho Excel ngay!

Công cụ năng suất văn phòng tốt nhất

🤖 Trợ lý AI của Kutools: Cách mạng hóa việc phân tích dữ liệu dựa trên: Thực thi thông minh   |  Tạo mã  |  Tạo công thức tùy chỉnh  |  Phân tích dữ liệu và tạo biểu đồ  |  Gọi các hàm Kutools...
Các tính năng phổ biến: Tìm, đánh dấu hoặc xác định các bản sao   |  Xóa hàng trống   |  Kết hợp các cột hoặc ô mà không làm mất dữ liệu   |   Vòng không có công thức hữu ích. Cảm ơn !
Siêu tra cứu: Nhiều tiêu chí VLookup    VLookup Nhiều Giá Trị  |   VLookup trên nhiều trang tính   |   Tra cứu mờ ....
Danh sách thả xuống nâng cao: Tạo nhanh danh sách thả xuống   |  Danh sách thả xuống phụ thuộc   |  Danh sách thả xuống nhiều lựa chọn ....
Trình quản lý cột: Thêm một số cột cụ thể  |  Di chuyển cột  |  Chuyển đổi trạng thái hiển thị của các cột ẩn  |  So sánh dãy và cột hữu ích. Cảm ơn !
Các tính năng nổi bật: Tiêu điểm lưới   |  Chế độ xem thiết kế   |   Thanh công thức lớn    Trình quản lý sổ làm việc & trang tính   |  Thư viện tài nguyên (Văn bản tự động)   |  Bảng chọn ngày   |  Kết hợp các bảng tính   |  Mã hóa/Giải mã ô    Gửi email theo danh sách   |  Siêu lọc   |   Bộ lọc đặc biệt (lọc in đậm/nghiêng/gạch ngang...) ...
15 bộ công cụ hàng đầu12 bản văn CÔNG CỤ (thêm văn bản, Xóa ký tự,...)   |   50 + Biểu đồ Các loại (Biểu đồ Gantt,...)   |   40+ Thực tế Công thức (Tính tuổi dựa trên ngày sinh,...)   |   19 chèn CÔNG CỤ (Chèn mã QR, Chèn ảnh từ đường dẫn,...)   |   12 Chuyển đổi CÔNG CỤ (Số thành từ, Chuyển đổi tiền tệ,...)   |   7 Hợp nhất & Tách CÔNG CỤ (Các hàng kết hợp nâng cao, Chia ô,...)   |   ... và nhiều hơn nữa

Nâng cao kỹ năng Excel của bạn với Kutools for Excel và trải nghiệm hiệu quả hơn bao giờ hết. Kutools for Excel cung cấp hơn 300 tính năng nâng cao để tăng năng suất và tiết kiệm thời gian.  Bấm vào đây để có được tính năng bạn cần nhất...

Mô tả


Tab Office mang lại giao diện Tab cho Office và giúp công việc của bạn trở nên dễ dàng hơn nhiều

  • Cho phép chỉnh sửa và đọc theo thẻ trong Word, Excel, PowerPoint, Publisher, Access, Visio và Project.
  • Mở và tạo nhiều tài liệu trong các tab mới của cùng một cửa sổ, thay vì trong các cửa sổ mới.
  • Tăng 50% năng suất của bạn và giảm hàng trăm cú nhấp chuột cho bạn mỗi ngày!
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