Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

macro to make rows read-only in excel

Posted on 2013-12-22
9
1,228 Views
Last Modified: 2013-12-28
folks

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

kindly share your code
0
Comment
Question by:rutgermons
  • 4
  • 2
  • 2
  • +1
9 Comments
 
LVL 27

Expert Comment

by:MacroShadow
ID: 39734565
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
 
LVL 50

Expert Comment

by:Rgonzo1971
ID: 39734566
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
 

Author Comment

by:rutgermons
ID: 39734758
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
Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

 
LVL 27

Expert Comment

by:MacroShadow
ID: 39734811
First unprotect the sheet, then have the macro do its thing, then lock row and protect sheet.
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39734826
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
 

Author Comment

by:rutgermons
ID: 39735059
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
 
LVL 46

Accepted Solution

by:
Martin Liss earned 500 total points
ID: 39735063
Move this to WorkBook_Open.

Sheets("XI End Points").Protect UserInterfaceOnly:=True
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39735069
Oh, and you don't need the "Locked" line.
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39735078
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

Networking for the Cloud Era

Join Microsoft and Riverbed for a discussion and demonstration of enhancements to SteelConnect:
-One-click orchestration and cloud connectivity in Azure environments
-Tight integration of SD-WAN and WAN optimization capabilities
-Scalability and resiliency equal to a data center

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction This Article briefly covers methods of calculating the NPV and IRR variants in Excel as well as the limitations in calculating and interpreting IRR results. Paraphrasing Richard Shockley, author of my favourite finance reference tex…
With User Account Control (UAC) enabled in Windows 7, one needs to open an elevated Command Prompt in order to run scripts under administrative privileges. Although the elevated Command Prompt accomplishes the task, the question How to run as script…
This Micro Tutorial will demonstrate in Google Sheets how to use the HYPERLINK function to create live links inside your spreadsheet.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

792 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question