Need macro to protect columns for the current month and the prior months

carlag12

New Member
Joined
Jan 29, 2019
Messages
3
Hello - I am new to writing macros. I know how to write a macro to protect ranges but I need one where I can protect certain columns based on the current month. For example i have an excel file with a column for each month of the year. For Jan I need to protect just the one column for Jan but when I get to Feb I need to protect Jan and Feb. I think it can be done if the macro uses the eomonth function and looks at a certain cell to know the date is 2/28/2019 but then how do I tell it to hide the column for Jan and Feb based on the date? Thanks!!!
 

Excel Facts

What is the shortcut key for Format Selection?
Ctrl+1 (the number one) will open the Format dialog for whatever is selected.
Hi Carlag,
okay, I'm assuming you have a worksheet with columns representing your months, identifiable by a header row with a date, the last day of the month?

What you than want in pseudo code:
unprotect sheet
loop through the months/columns
if the month of the date in that header row is before the month of today (or a cell with a date setting), hide that column
if the month of the date in that header row is the month of today (or a cell with a date setting), show the column and unprotect it
if the month of the date in that header row is after the month of today (or a cell with a date setting), show the column but protect it
protect the sheet

Is that what you more or less want? If so, do start by recording a macro going manually through some steps (like unprotecting, hiding a column). If you can post that code here (see my signature on how to), someone here can help you adding a loop to it. And two easy free VBA courses: http://www.homeandlearn.org/ & https://www.excel-easy.com/vba.html

Cheers,

Koen
 
Upvote 0
Hi Carlag,
okay, I'm assuming you have a worksheet with columns representing your months, identifiable by a header row with a date, the last day of the month?

What you than want in pseudo code:
unprotect sheet
loop through the months/columns
if the month of the date in that header row is before the month of today (or a cell with a date setting), hide that column
if the month of the date in that header row is the month of today (or a cell with a date setting), show the column and unprotect it
if the month of the date in that header row is after the month of today (or a cell with a date setting), show the column but protect it
protect the sheet

Is that what you more or less want? If so, do start by recording a macro going manually through some steps (like unprotecting, hiding a column). If you can post that code here (see my signature on how to), someone here can help you adding a loop to it. And two easy free VBA courses: http://www.homeandlearn.org/ & https://www.excel-easy.com/vba.html

Cheers,

Koen


Hi Koen thank

Here is my code - I am trying to protect any columns in range D2:J2 where the month which is a numerical value is <= to a value in a cell B2

Sub test()




Dim x As Range


Dim strPassword As String


For Each x In Range("D2:J2").Cells


If x.Value <= Range("B2") Then


x.EntireColumn.Locked = True


ActiveSheet.Protect Password:="hello"


End If


Next x


End Sub
 
Upvote 0
Hi carlag,
that is close, try this:

Code:
Sub test()

Dim x As Range
Dim strPassword As String

ActiveSheet.Unprotect Password:="hello"

For Each x In Range("D2:J2").Cells
    If x.Value <= Range("B2") Then
        x.EntireColumn.Locked = True
    End If
Next x

ActiveSheet.Protect Password:="hello"


End Sub
Cheers,
Koen
 
Upvote 0

Forum statistics

Threads
1,223,898
Messages
6,175,274
Members
452,628
Latest member
dd2

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top