Solved

Pass word protect named ranges

Posted on 2012-03-26
7
273 Views
Last Modified: 2012-03-26
Hi,

I have a list of names and columns of data, i am going to name all these ranges

I would like some code that if you click anywhere in that named range you get prompted to enter a password that i can nominate

Has anyone got such code?

Thanks
Seamus
0
Comment
Question by:Seamus2626
  • 4
  • 2
7 Comments
 
LVL 12

Expert Comment

by:kgerb
ID: 37766279
This this code.  Paste it into the worksheet code pane for the worksheet containing the cells you want to protect.  Modify the code to match the range names in your worksheet.  I used names rngTemp1, rngTemp2, rngTemp3.

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim PWord As String
PWord = "MyPassword"
If Not Application.Intersect(Range("rngTemp1"), Target) Is Nothing Then
    If Not PWordIsCorrect(PWord) Then Range("A1").Select
ElseIf Not Application.Intersect(Range("rngTemp2"), Target) Is Nothing Then
    If Not PWordIsCorrect(PWord) Then Range("A1").Select
ElseIf Not Application.Intersect(Range("rngTemp3"), Target) Is Nothing Then
    If Not PWordIsCorrect(PWord) Then Range("A1").Select
End If
End Sub

Function PWordIsCorrect(sPass As String) As Boolean
Dim s As String
s = InputBox("Enter the password", "Password required")
If s = sPass Then PWordIsCorrect = True Else PWordIsCorrect = False
End Function

Open in new window

Kyle
Q-27648596-RevA.xlsm
0
 
LVL 3

Expert Comment

by:DaFranker
ID: 37766299
Small hint for using Kyle's solution:

You'll ideally want to protect the VBProject and the workbook itself with a password too, otherwise nothing's stopping the users from hitting ALT+F11 and looking at the code to find the right password.
0
 
LVL 12

Expert Comment

by:kgerb
ID: 37766366
Here's an updated version.  I made the assumption that as soon as someone entered the correct password they should be allowed to keep working in the range until they clicked outside the boundaries.  At that point they will need to enter the password again to re-enter the range.  You will need to specify a cell into which the code can dump a variable.  In the example I used "I2".  Modify as necessary.
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim PWord As String
PWord = "MyPassword"
If Not Application.Intersect(Range("rngTemp1"), Target) Is Nothing Then
    If Range("I2") <> "r1" Then
        If Not PWordIsCorrect(PWord) Then Range("A1").Select Else Range("I2") = "r1"
    End If
ElseIf Not Application.Intersect(Range("rngTemp2"), Target) Is Nothing Then
    If Range("I2") <> "r2" Then
        If Not PWordIsCorrect(PWord) Then Range("A1").Select Else Range("I2") = "r2"
    End If
ElseIf Not Application.Intersect(Range("rngTemp3"), Target) Is Nothing Then
    If Range("I2") <> "r3" Then
        If Not PWordIsCorrect(PWord) Then Range("A1").Select Else Range("I2") = "r3"
    End If
Else
    Range("I2") = "Nothing"
End If
End Sub

Function PWordIsCorrect(sPass As String) As Boolean
Dim s As String
s = InputBox("Enter the password", "Password required")
If s = sPass Then PWordIsCorrect = True Else PWordIsCorrect = False
End Function

Open in new window

Kyle
0
Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

 

Author Comment

by:Seamus2626
ID: 37766455
That looks really good Kyle, but i need each range to have a different password, not one password for the whole lot

Thanks
Seamus
0
 
LVL 12

Accepted Solution

by:
kgerb earned 500 total points
ID: 37766486
Here you go.  Now you need to specify a unique password for each range.  Modify as necessary.
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Dim sPW1 As String, sPW2 As String, sPW3 As String
sPW1 = "PW1"
sPW2 = "PW2"
sPW3 = "PW3"
If Not Application.Intersect(Range("rngTemp1"), Target) Is Nothing Then
    If Range("I2") <> "r1" Then
        If Not PWordIsCorrect(sPW1) Then Range("A1").Select Else Range("I2") = "r1"
    End If
ElseIf Not Application.Intersect(Range("rngTemp2"), Target) Is Nothing Then
    If Range("I2") <> "r2" Then
        If Not PWordIsCorrect(sPW2) Then Range("A1").Select Else Range("I2") = "r2"
    End If
ElseIf Not Application.Intersect(Range("rngTemp3"), Target) Is Nothing Then
    If Range("I2") <> "r3" Then
        If Not PWordIsCorrect(sPW3) Then Range("A1").Select Else Range("I2") = "r3"
    End If
Else
    Range("I2") = "Nothing"
End If
End Sub

Function PWordIsCorrect(sPass As String) As Boolean
Dim s As String
s = InputBox("Enter the password", "Password required")
If s = sPass Then PWordIsCorrect = True Else PWordIsCorrect = False
End Function

Open in new window

Kyle
0
 

Author Closing Comment

by:Seamus2626
ID: 37766516
Thank you very much Kyle, thanks too  DaFranke, i will lock the project

Cheers,
Seamus
0
 
LVL 12

Expert Comment

by:kgerb
ID: 37766552
You're welcome.  Glad to help.
Kyle
0

Featured Post

Courses: Start Training Online With Pros, Today

Brush up on the basics or master the advanced techniques required to earn essential industry certifications, with Courses. Enroll in a course and start learning today. Training topics range from Android App Dev to the Xen Virtualization Platform.

Question has a verified solution.

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

Suggested Solutions

How to quickly and accurately populate Word documents with Excel data, charts and images (including Automated Bookmark generation) David Miller (dlmille) Synopsis In this article you’ll learn how to use ExcelToWord! to copy data,charts, shapes …
Workbook link problems after copying tabs to a new workbook? David Miller (dlmille) Intro Have you either copied sheets to a new workbook, and after having saved and opened that workbook, you find that there are links back to the original sou…
The viewer will learn how to create two correlated normally distributed random variables in Excel, use a normal distribution to simulate the return on different levels of investment in each of the two funds over a period of ten years, and, create a …
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…

805 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