<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FExcel%2FWorksheet_Protection</id>
		<title>VBA/Excel/Access/Word/Excel/Worksheet Protection - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.vbex.ru/index.php?action=history&amp;feed=atom&amp;title=VBA%2FExcel%2FAccess%2FWord%2FExcel%2FWorksheet_Protection"/>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Worksheet_Protection&amp;action=history"/>
		<updated>2026-04-07T03:39:06Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Worksheet_Protection&amp;diff=1682&amp;oldid=prev</id>
		<title> в 16:33, 26 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Worksheet_Protection&amp;diff=1682&amp;oldid=prev"/>
				<updated>2010-05-26T16:33:00Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 16:33, 26 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Worksheet_Protection&amp;diff=1683&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.vbex.ru/index.php?title=VBA/Excel/Access/Word/Excel/Worksheet_Protection&amp;diff=1683&amp;oldid=prev"/>
				<updated>2010-05-26T12:47:52Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Add protection to Worksheet==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub Set_Protection()&lt;br /&gt;
    On Error GoTo errorHandler&lt;br /&gt;
    Dim myDoc As Worksheet&lt;br /&gt;
    Dim cel As Range&lt;br /&gt;
    Set myDoc = ActiveSheet&lt;br /&gt;
    myDoc.Unprotect&lt;br /&gt;
    For Each cel In myDoc.UsedRange&lt;br /&gt;
        cel.Locked = True&lt;br /&gt;
        cel.Font.ColorIndex = xlColorIndexAutomatic&lt;br /&gt;
    Next&lt;br /&gt;
    myDoc.Protect&lt;br /&gt;
    Exit Sub&lt;br /&gt;
    errorHandler:&lt;br /&gt;
    MsgBox Error&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Add user edit range==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub AddUserEditRange()&lt;br /&gt;
    Dim ws As Worksheet, aer As AllowEditRange&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Unprotect &amp;quot;Excel2003&amp;quot;&lt;br /&gt;
    Set aer = ws.Protection.AllowEditRanges.Add(&amp;quot;User Range&amp;quot;, ws.Range(&amp;quot;A1:D4&amp;quot;))&lt;br /&gt;
    aer.Users.Add &amp;quot;Power Users&amp;quot;, True&lt;br /&gt;
    ws.Protect &amp;quot;Excel2003&amp;quot;&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Formulas Protection==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub ProtectFormulas()&lt;br /&gt;
    Dim ws As Worksheet, rng As Range&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Unprotect&lt;br /&gt;
    &amp;quot; Get each used cell in the worksheet.&lt;br /&gt;
    For Each rng In ws.UsedRange&lt;br /&gt;
        &amp;quot; If it contains a formula, lock the cell.&lt;br /&gt;
        If InStr(rng.Formula, &amp;quot;=&amp;quot;) Then&lt;br /&gt;
            rng.Locked = True&lt;br /&gt;
        &amp;quot; Otherwise unlock the cell.&lt;br /&gt;
        Else&lt;br /&gt;
            rng.Locked = False&lt;br /&gt;
        End If&lt;br /&gt;
    Next&lt;br /&gt;
    ws.Protect &amp;quot;Excel2003&amp;quot;&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Protecting Worksheet Assets with the Protect Method==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub TestProtection() &lt;br /&gt;
    Dim ws As Worksheet &lt;br /&gt;
    Set ws = ThisWorkbook.Worksheets(1) &lt;br /&gt;
    If Not ProtectWorksheet(ws, &amp;quot;TestPassword&amp;quot;) Then &lt;br /&gt;
        Debug.Print &amp;quot;The worksheet could not be protected.&amp;quot; &lt;br /&gt;
    Else &lt;br /&gt;
        Debug.Print &amp;quot;The worksheet has been protected.&amp;quot; &lt;br /&gt;
    End If &lt;br /&gt;
    If UnprotectWorksheet(ws, &amp;quot;TestPassword&amp;quot;) Then &lt;br /&gt;
        Debug.Print &amp;quot;The worksheet has been unprotected.&amp;quot; &lt;br /&gt;
    Else &lt;br /&gt;
        Debug.Print &amp;quot;The worksheet could not be unprotected.&amp;quot; &lt;br /&gt;
    End If &lt;br /&gt;
    Set ws = Nothing &lt;br /&gt;
End Sub &lt;br /&gt;
Function ProtectWorksheet(ws As Worksheet, sPassword As String) As Boolean &lt;br /&gt;
    On Error GoTo ErrHandler &lt;br /&gt;
    If Not ws.ProtectContents Then &lt;br /&gt;
        ws.Protect sPassword, True, True, True &lt;br /&gt;
    End If &lt;br /&gt;
    ProtectWorksheet = True &lt;br /&gt;
    Exit Function &lt;br /&gt;
ErrHandler: &lt;br /&gt;
    ProtectWorksheet = False &lt;br /&gt;
End Function &lt;br /&gt;
Function UnprotectWorksheet(ws As Worksheet, sPassword As String) As Boolean &lt;br /&gt;
    On Error GoTo ErrHandler &lt;br /&gt;
    If ws.ProtectContents Then &lt;br /&gt;
        ws.Unprotect sPassword &lt;br /&gt;
    End If &lt;br /&gt;
    UnprotectWorksheet = True &lt;br /&gt;
    Exit Function &lt;br /&gt;
ErrHandler: &lt;br /&gt;
    UnprotectWorksheet = False &lt;br /&gt;
End Function &lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Protect Sheet==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub ProtectSheet()&lt;br /&gt;
    Dim ws As Worksheet&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Protect &amp;quot;Excel2003&amp;quot;, , True, , True&lt;br /&gt;
    ws.Range(&amp;quot;A1&amp;quot;).Value = 42&lt;br /&gt;
    Debug.Print ws.ProtectContents&lt;br /&gt;
    Debug.Print ws.ProtectDrawingObjects&lt;br /&gt;
    Debug.Print ws.ProtectionMode&lt;br /&gt;
    Debug.Print ws.ProtectScenarios&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==remove user==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub RemoveUser()&lt;br /&gt;
    Dim ws As Worksheet, rng As Range, aer As AllowEditRange&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Unprotect&lt;br /&gt;
    Set aer = ws.Protection.AllowEditRanges(&amp;quot;User Range&amp;quot;)&lt;br /&gt;
    aer.Users(&amp;quot;Power Users&amp;quot;).Delete&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Remove user edit range==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub RemoveUserEditRange()&lt;br /&gt;
    Dim ws As Worksheet, rng As Range, aer As AllowEditRange&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Unprotect&lt;br /&gt;
    For Each aer In ws.Protection.AllowEditRanges&lt;br /&gt;
        aer.Delete&lt;br /&gt;
    Next&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Show Protection Properties==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub ShowProtectionProperties()&lt;br /&gt;
    Dim ws As Worksheet, prot As Protection&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    Set prot = ws.Protection&lt;br /&gt;
    Debug.Print prot.AllowDeletingColumns&lt;br /&gt;
    Debug.Print prot.AllowDeletingRows&lt;br /&gt;
    Debug.Print prot.AllowFiltering&lt;br /&gt;
    Debug.Print prot.AllowSorting&lt;br /&gt;
    Debug.Print prot.AllowUsingPivotTables&lt;br /&gt;
    Debug.Print prot.AllowFormattingCells&lt;br /&gt;
    Debug.Print prot.AllowFormattingColumns&lt;br /&gt;
    Debug.Print prot.AllowFormattingRows&lt;br /&gt;
    Debug.Print prot.AllowInsertingColumns&lt;br /&gt;
    Debug.Print prot.AllowInsertingRows&lt;br /&gt;
    Debug.Print prot.AllowInsertingHyperlinks&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Unprotect worksheet==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;vb&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
Sub UnprotectWS()&lt;br /&gt;
    Dim ws As Worksheet&lt;br /&gt;
    Set ws = ThisWorkbook.Sheets(&amp;quot;Protection&amp;quot;)&lt;br /&gt;
    ws.Unprotect &amp;quot;Excel2003&amp;quot;&lt;br /&gt;
End Sub&lt;br /&gt;
 &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>