• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1495
  • Last Modified:

macro to make rows read-only in excel

folks

How can I make a row read-only in a sheet via a macro?

kindly share your code
0
rutgermons
Asked:
rutgermons
  • 4
  • 2
  • 2
  • +1
1 Solution
 
MacroShadowCommented:
This will lock the first row, to lock a different row just change the row number of the ranges.

Sub Demo()
    Range("A1:XFD1").Locked = True
    ActiveSheet.Protect Contents:=True
End Sub

Open in new window


Note: locking cells only applies when the sheet is protected, hence the second line of code.
0
 
Rgonzo1971Commented:
Hi,

pls try
Sub Macro5()

    ActiveSheet.Unprotect
    Cells.Locked = False
    Range("1:1").Locked = True
    ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True
End Sub

Open in new window

EDIT By default cells are locked, if you protect without unlocking the other cells, you will lock all of them

Regards
0
 
rutgermonsAuthor Commented:
folks

thanks! can I though ensure the rows are locked but manual user input but not if the same macro wants to update the rows?
0
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
MacroShadowCommented:
First unprotect the sheet, then have the macro do its thing, then lock row and protect sheet.
0
 
Martin LissRetired ProgrammerCommented:
Instead of locking and unlocking and taking the (very small) chance that the user will change the sheet before it's locked again, just do this instead of locking.

ActiveSheet.Protect UserInterfaceOnly:=True

If that's done the sheet will be locked but code can run against it.
0
 
rutgermonsAuthor Commented:
Martin

I used your code in

 Sheets("XI End Points").Cells(c6, 1).Value = Me.ComboBox1.Value
    Sheets("XI End Points").Cells(c6, 2).Value = Me.ComboBox1.Column(4)
    Sheets("XI End Points").Cells(c6, 3).Value = Me.ComboBox1.Column(5)
    Sheets("XI End Points").Cells(c6, 4).Value = Me.ComboBox1.Column(6)
    Range("A3:XFD1").Locked = True
    Sheets("XI End Points").Protect UserInterfaceOnly:=True

no luck

any ideas?
0
 
Martin LissRetired ProgrammerCommented:
Move this to WorkBook_Open.

Sheets("XI End Points").Protect UserInterfaceOnly:=True
0
 
Martin LissRetired ProgrammerCommented:
Oh, and you don't need the "Locked" line.
0
 
Martin LissRetired ProgrammerCommented:
One more thing. You probably know this but just in case...

After you move that line to Workbook_Open you either have to close and reopen the workbook or run that sub from Visual Basic.
0

Featured Post

Hire Technology Freelancers with Gigs

Work with freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely, and get projects done right.

  • 4
  • 2
  • 2
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now