这里的Excel VBA非常新...非常类似于这篇文章:Avoiding the use of Activate and Select when working with charts (Excel),我试图避免使用Activate来对大型工作簿中的大量图表进行小的更改。我正在为大量图表执行此任务,因此我希望尽可能减少运行时间并听说选择/激活函数会降低宏的速度。
我的示例代码如下所示:
ActiveSheet.ChartObjects("Chart 3").Activate
ActiveChart.FullSeriesCollection(1).XValues = "=Leb!$C$2:$G$2"
我试图用以下内容替换这两行,因为这对我来说具有逻辑意义:
ActiveSheet.ChartObjects("Chart 3").FullSeriesCollection(1).XValues = "=Leb!$C$2:$G$2"
此代码在运行时导致错误,因此我尝试使用上述帖子显示的WITH格式:
With Worksheets("Chart").ChartObjects("Chart 3").Chart.XValues = "=Leb!$C$2:$G$2"
End With
这也会引发错误。
我知道我可能会犯一个小的语法错误,但是任何人都可以提供任何有关我做错的信息吗? (我之前从未使用过WITH函数,所以对它的一些一般见解也会非常有用。)
提前致谢。
答案 0 :(得分:2)
差不多......
With Worksheets("Chart").ChartObjects("Chart 3").Chart
.SeriesCollection(1).XValues = "=Leb!$C$2:$G$2"
End With
XValues
属于Series
对象,而不是图表(指您的上一个代码示例)。
编辑:
Dim arrCharts, cht
arrCharts = Array("Chart 3", "Chart 4", "Chart 5", "Chart 7")
For Each cht In arrCharts
With Worksheets("Chart").ChartObjects(cht).Chart
.SeriesCollection(1).XValues = "=Leb!$C$2:$G$2"
End With
Next cht