首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VBA:动态范围的Protection.AllowEditRanges

VBA:动态范围的Protection.AllowEditRanges
EN

Stack Overflow用户
提问于 2015-10-22 12:34:08
回答 1查看 1.6K关注 0票数 1

昨天我问了一个问题(Marking an area with a double 'For' loop),@Excel给了我一个很好的回答。我使用他的代码将一个范围存储在变量‘k’中:

代码语言:javascript
复制
Sub ErosRam()
    Dim i&, j&, area$, k As Range, r As Range

    Const COL_PERIOD = 3
    Const ROW_PERIOD = 3
    Const REPS_HORIZONTAL = 3
    Const REPS_VERTICAL = 2

    Set r = [f7:g8]
    Set k = r

    For i = 0 To REPS_VERTICAL - 1
        For j = 0 To REPS_HORIZONTAL - 1
            Set k = Union(k, r.Offset(i * ROW_PERIOD, j * COL_PERIOD))
        Next
    Next

    area = k.Address(0, 0)
    MsgBox area   
End Sub

现在,我希望保持'k‘给出的区域未锁定,并锁定其余的。所以我想用这样的词:

代码语言:javascript
复制
     ActiveSheet.Protection.AllowEditRanges.Add Title:="test", Range:=Range(k)

但这行不通。如何在protection.alloweditranges中使用变量范围?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-22 12:45:00

它已经是一个范围,所以您不想用Range()方法包装k:

代码语言:javascript
复制
ActiveSheet.Protection.AllowEditRanges.Add Title:="test", Range:=k
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33281166

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档