首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >VBA动态范围

VBA动态范围
EN

Stack Overflow用户
提问于 2019-03-15 06:10:14
回答 1查看 34关注 0票数 0

对VBA来说还是个新手。我有一个宏,我想要将其更改为能够处理工作表中包含数据的行数,而不是硬编码值(46)。

Sub test1calc()
'
' test1calc Macro
'

'
'1 - UNSTRESSED POSTED PRODUCT LEVEL BREAKDOWN SUMMED AT NETTING SET
    Columns("AS:AS").Select
    Selection.Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove
    Range("AS1").Select
    Selection.Interior.Pattern = xlSolid
    Selection.Interior.PatternColorIndex = 2
    Selection.Interior.Color = 65535
    ActiveCell.FormulaR1C1 = "Unstressed Posted Total"
    Range("AS2").Select
    ActiveCell.FormulaR1C1 = "=SUM(RC[-30]:RC[-1])"
    Range("AS2").Select
    Selection.AutoFill Destination:=Range("AS2:AS46")
    Range("AS2:AS46").Select
    ActiveSheet.Calculate
    Selection.Copy
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
        :=False, Transpose:=False
    Application.CutCopyMode = False
End Sub
EN

回答 1

Stack Overflow用户

发布于 2019-03-15 06:24:51

我假设您想要填充左侧有现有数据的行,而不是工作表中存在的数百万行。

如果是这样的话,我相信你的代码可以简化为:

Sub test1calc()

    '1 - UNSTRESSED POSTED PRODUCT LEVEL BREAKDOWN SUMMED AT NETTING SET

    Columns("AS:AS").Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove

    With Range("AS1")
        .Interior.Pattern = xlSolid
        .Interior.PatternColorIndex = 2
        .Interior.Color = 65535
        .Value = "Unstressed Posted Total"
    End With

    With Range("AS2:AS" & Range("O" & Rows.Count).End(xlUp).Row)
         .FormulaR1C1 = "=SUM(RC[-30]:RC[-1])"
         .Value = .Value
    End With

End Sub
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55172768

复制
相关文章

相似问题

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