我有一个 Excel VBA 应用程序,该应用程序在 Excel 2003 中运行良好,但在 Excel 2010 中失败。
相关代码为
Public Sub Create_Chart
Dim c
Dim OutputText As String
OutputText = OutputSource
Workbooks(NewWorkBook).Activate
With ActiveSheet
obj.Range(DataRange).NumberFormat = "0.0%"
ActiveSheet.ChartObjects(1).Activate
ActiveChart.ChartArea.Select
ActiveChart.SetSourceData Source:=obj.Range(DataRange)
End With
End Sub
The error message appears when debugger hits ActiveChart.SetSourceData Source:=objNBR.Range(DataRange) with this window -
The DataRange in debugger is F2:R2, F3:R3 with the obj pointing to the right Excel form -
The the ActiveChart is from a template -
我的调试器显示“ActiveChart.ChartArea.Select”为 true。 ActiveChart 和 obj 是有效对象。
Most important is that Excel 2003 works fine. I use the debugger to compare the Excel 2003 and 2010 obj and ActiveChart. And I can not find much different in terms of codes. I do see my template for the ActiveChart is a bit different in 2003 -
原始模板与 2010 年显示的完全相同,但在复制到 2003 年工作表时已自动清零。这是我在 2003 年和 2010 年之间注意到的唯一差异。我不确定这是否会导致此错误。
我不确定我是否遗漏了任何证据。错误消息没有提供太多详细信息。还有其他方法可以获取更多调试信息吗?
如果有人能帮助我找到问题并解决问题,我将不胜感激。
提前致谢
Edit1:obj 在另一个例程中创建,并且 DataRange 在该例程中填充 -
Workbooks.Add
MyWorkbook = ActiveWorkbook.Name
Set obj = ActiveWorkbook.Worksheets(1)
然后将数据插入到 DataRange 单元格 - F2:R2、F3:R3。我可以看到 Excel 文件显示了正确的数据。
Edit2上面子中的工作簿(NewWorkBook)是从这些代码生成的,我可以看到新的 Excel 和图表显示在屏幕上 -
Windows(Dir(TemplateFile)).Activate
ActiveWorkbook.Sheets("C1").Select
ActiveWorkbook.Sheets("C1").Copy
NewWorkBook = ActiveWorkbook.Name
Windows(NewWorkBook).Visible = True
Edit3使用 Sid 的方法首先以这种方式声明对象 -
Public Sub Create_Chart()
Dim wb As Workbook
Dim ws As Worksheet
Dim objChrt As ChartObject
Dim Chrt As chart
Set wb = Workbooks(NewWorkBook)
Set ws = wb.Sheets(1)
Set objChrt = ws.ChartObjects(1)
Set Chrt = objChrt.chart
With wb
obj.Range(DataRange).NumberFormat = "0.0%"
'Chrt.Export ("c:\temp\testChrt.gif")
'With obj.PageSetup
' .PrintArea = DataRange
' .Zoom = False
' .FitToPagesTall = 1
' .FitToPagesWide = 1
' .Orientation = xlLandscape
' End With
' obj.PrintOut Copies:=1
Chrt.SetSourceData Source:=obj.Range(DataRange)
End With
End Sub
错误是完全相同的。请注意,我有注释掉的代码来打印并保存 Chrt 和 obj.Range(DataRange) 对象。这些值与上面的图 2 和图 3 相同。所以图表和数据就在那里。我只是想知道为什么“Chrt.SetSourceData Source:=obj.Range(DataRange)”在 2010 年的这种情况下不起作用,但在 2003 年却起作用。