首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >宏:录制的宏不起作用

宏:录制的宏不起作用
EN

Stack Overflow用户
提问于 2013-11-11 17:57:03
回答 2查看 817关注 0票数 1

我使用Record Macro option在excel中录制了一个宏。但是,当我运行它时,我得到了Error 438,错误框显示Object does not support property or method。下面是生成的宏代码。有人能在这里解释一下吗:

代码语言:javascript
运行
复制
Sub Macro1()
'
' Macro1 Macro
'

'
    ActiveCell.Range("A1:C1").Select
    ActiveSheet.Shapes.AddChart.Select
    ActiveChart.SetSourceData Source:=Range("'Sheet2'!$A$4:$C$4")
    ActiveChart.ChartType = xlPie
    Application.CutCopyMode = True
    Selection.Cut
    Sheets("Sheet3").Select
    ActiveSheet.Paste
    Sheets("Sheet2").Select
    ActiveCell.Offset(1, 0).Range("A1").Select

当我调试时,我在Selection.Cut中得到错误。我想知道为什么录制的宏会生成不能工作的代码

EN

回答 2

Stack Overflow用户

发布于 2013-11-11 18:11:58

虽然不是一个好方法,

但是将Selection.Cut更改为Selection.Parent.Parent.Cut应该是可行的。

请记住,请尽可能避免使用Select

票数 0
EN

Stack Overflow用户

发布于 2013-11-11 20:59:54

稍微打磨过的版本(使用引用和避免选择),应该可以工作:

代码语言:javascript
运行
复制
Sub Macro1()
' Macro1 Macro
    Dim ws1 As Worksheet, ws2 As Worksheet
    Set ws1 = ActiveSheet   ' This is likely 'Sheet 1'
    Dim rng As Range
    Set rng = ActiveCell.Range("A1:C1")
    Dim shp As Shape
    Set shp = ws1.Shapes.AddChart
    shp.Chart.SetSourceData Source:=Range("'Sheet2'!$A$4:$C$4")
    shp.Chart.ChartType = xlPie
    Application.CutCopyMode = True
    shp.Cut
    Sheets("Sheet3").Paste
    Set ws2 = Sheets("Sheet2")
    ws2.Activate
    ActiveCell.Offset(1, 0).Range("A1").Select
End Sub
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19903422

复制
相关文章

相似问题

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